mirror of
				https://github.com/MichMich/MagicMirror.git
				synced 2025-10-25 13:17:42 +00:00 
			
		
		
		
	Switched to SVG graphics for scalability
(cherry picked from commit 15f0956b60ec0d16302875bd53dcc037581ad96b)
This commit is contained in:
		| @@ -83,7 +83,7 @@ The following properties can be configured: | |||||||
| 		<tr> | 		<tr> | ||||||
| 			<td><code>analogFace</code></td> | 			<td><code>analogFace</code></td> | ||||||
| 			<td><strong>Specific to the analog clock.</strong> Specifies which clock face to use.<br> | 			<td><strong>Specific to the analog clock.</strong> Specifies which clock face to use.<br> | ||||||
| 				<br><b>Possible values:</b> <code>false</code> for a default border, <code>none</code> for no face or border, or <code>face-###</code> (where ### is currently a value between 001 and 008, inclusive) | 				<br><b>Possible values:</b> <code>simple</code> for a simple border, <code>none</code> for no face or border, or <code>face-###</code> (where ### is currently a value between 001 and 012, inclusive) | ||||||
| 				<br><b>Default value:</b> <code>false</code> | 				<br><b>Default value:</b> <code>false</code> | ||||||
| 			</td> | 			</td> | ||||||
| 		</tr> | 		</tr> | ||||||
|   | |||||||
| @@ -8,16 +8,18 @@ | |||||||
| Module.register("clock",{ | Module.register("clock",{ | ||||||
| 	// Module config defaults. | 	// Module config defaults. | ||||||
| 	defaults: { | 	defaults: { | ||||||
|  | 		displayType: 'digital', // options: digital, analog, both | ||||||
|  |  | ||||||
| 		timeFormat: config.timeFormat, | 		timeFormat: config.timeFormat, | ||||||
| 		displaySeconds: true, | 		displaySeconds: true, | ||||||
| 		showPeriod: true, | 		showPeriod: true, | ||||||
| 		showPeriodUpper: false, | 		showPeriodUpper: false, | ||||||
| 		clockBold: false, | 		clockBold: false, | ||||||
| 		displayType: 'digital', // options: digital, analog, both |  | ||||||
| 		/* specific to the analog clock */ | 		/* specific to the analog clock */ | ||||||
| 		analogSize: '200px', | 		analogSize: '200px', | ||||||
| 		analogFace: false, | 		analogFace: 'simple', // options: 'none', 'simple', 'face-###' (where ### is 001 to 012 inclusive) | ||||||
| 		analogPlacement: 'bottom', | 		analogPlacement: 'bottom', // options: top, bottom, left, right | ||||||
| 		secondsColor: '#888888', | 		secondsColor: '#888888', | ||||||
| 	}, | 	}, | ||||||
| 	// Define required scripts. | 	// Define required scripts. | ||||||
| @@ -40,6 +42,7 @@ Module.register("clock",{ | |||||||
|  |  | ||||||
| 		// Set locale. | 		// Set locale. | ||||||
| 		moment.locale(config.language); | 		moment.locale(config.language); | ||||||
|  |  | ||||||
| 	}, | 	}, | ||||||
| 	// Override dom generator. | 	// Override dom generator. | ||||||
| 	getDom: function() { | 	getDom: function() { | ||||||
| @@ -108,24 +111,25 @@ Module.register("clock",{ | |||||||
|  |  | ||||||
| 		 if (this.config.displayType !== 'digital') { | 		 if (this.config.displayType !== 'digital') { | ||||||
| 			// If it isn't 'digital', then an 'analog' clock was also requested | 			// If it isn't 'digital', then an 'analog' clock was also requested | ||||||
|  |  | ||||||
|  | 			// Calculate the degree offset for each hand of the clock | ||||||
| 			var now = moment(), | 			var now = moment(), | ||||||
| 				second = now.seconds() * 6, | 				second = now.seconds() * 6, | ||||||
| 				minute = now.minute() * 6 + second / 60, | 				minute = now.minute() * 6 + second / 60, | ||||||
| 				hour = ((now.hours() % 12) / 12) * 360 + 90 + minute / 12; | 				hour = ((now.hours() % 12) / 12) * 360 + 90 + minute / 12; | ||||||
|  |  | ||||||
| 			// Create wrappers | 			// Create wrappers | ||||||
|  |  | ||||||
| 			var wrapper = document.createElement("div"); | 			var wrapper = document.createElement("div"); | ||||||
| 			var clockCircle = document.createElement("div"); | 			var clockCircle = document.createElement("div"); | ||||||
| 			clockCircle.className = "clockCircle"; | 			clockCircle.className = "clockCircle"; | ||||||
| 			clockCircle.style.width = this.config.analogSize; | 			clockCircle.style.width = this.config.analogSize; | ||||||
| 			clockCircle.style.height = this.config.analogSize; | 			clockCircle.style.height = this.config.analogSize; | ||||||
|  |  | ||||||
| 			if ((this.config.analogFace != '' || this.config.analogFace != false) && this.config.analogFace !== 'none') { | 			if (this.config.analogFace != '' && this.config.analogFace != 'simple' && this.config.analogFace != 'none') { | ||||||
| 				clockCircle.style.background = "url("+ this.data.path + "/faces/" + this.config.analogFace + ".svg)" | 				clockCircle.style.background = "url("+ this.data.path + "faces/" + this.config.analogFace + ".svg)"; | ||||||
| 				clockCircle.style.backgroundSize = "100%"; | 				clockCircle.style.backgroundSize = "100%"; | ||||||
| 			} else if (this.config.analogFace != 'none') { | 			} else if (this.config.analogFace != 'none') { | ||||||
| 				clockCircle.style.border = "5px double white"; | 				clockCircle.style.border = "2px solid white"; | ||||||
| 			} | 			} | ||||||
| 			var clockFace = document.createElement("div"); | 			var clockFace = document.createElement("div"); | ||||||
| 			clockFace.className = "clockFace"; | 			clockFace.className = "clockFace"; | ||||||
| @@ -138,16 +142,17 @@ Module.register("clock",{ | |||||||
| 			clockMinute.id = "clockMinute"; | 			clockMinute.id = "clockMinute"; | ||||||
| 			clockMinute.style.transform = "rotate(" + minute + "deg)"; | 			clockMinute.style.transform = "rotate(" + minute + "deg)"; | ||||||
| 			clockMinute.className = "clockMinute"; | 			clockMinute.className = "clockMinute"; | ||||||
| 			var clockSecond = document.createElement("div"); |  | ||||||
| 			clockSecond.id = "clockSecond"; |  | ||||||
| 			clockSecond.style.transform = "rotate(" + second + "deg)"; |  | ||||||
| 			clockSecond.className = "clockSecond"; |  | ||||||
| 			clockSecond.style.backgroundColor = this.config.secondsColor; |  | ||||||
|  |  | ||||||
| 			// Combine analog wrappers | 			// Combine analog wrappers | ||||||
| 			clockFace.appendChild(clockHour); | 			clockFace.appendChild(clockHour); | ||||||
| 			clockFace.appendChild(clockMinute); | 			clockFace.appendChild(clockMinute); | ||||||
|  |  | ||||||
| 			if (this.config.displaySeconds) { | 			if (this.config.displaySeconds) { | ||||||
|  | 				var clockSecond = document.createElement("div"); | ||||||
|  | 				clockSecond.id = "clockSecond"; | ||||||
|  | 				clockSecond.style.transform = "rotate(" + second + "deg)"; | ||||||
|  | 				clockSecond.className = "clockSecond"; | ||||||
|  | 				clockSecond.style.backgroundColor = this.config.secondsColor; | ||||||
| 				clockFace.appendChild(clockSecond); | 				clockFace.appendChild(clockSecond); | ||||||
| 			} | 			} | ||||||
| 			clockCircle.appendChild(clockFace); | 			clockCircle.appendChild(clockFace); | ||||||
| @@ -164,7 +169,7 @@ Module.register("clock",{ | |||||||
| 		} else if (this.config.displayType === 'analog') { | 		} else if (this.config.displayType === 'analog') { | ||||||
| 			// Display only an analog clock | 			// Display only an analog clock | ||||||
| 			dateWrapper.style.textAlign = "center"; | 			dateWrapper.style.textAlign = "center"; | ||||||
| 			dateWrapper.style.paddingBottom = "10px"; | 			dateWrapper.style.paddingBottom = "15px"; | ||||||
| 			wrapper.appendChild(dateWrapper); | 			wrapper.appendChild(dateWrapper); | ||||||
| 			wrapper.appendChild(clockCircle); | 			wrapper.appendChild(clockCircle); | ||||||
| 		} else { | 		} else { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user