Compare commits
	
		
			3 Commits
		
	
	
		
			latest_rel
			...
			3746622a11
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 3746622a11 | |||
| ccd50cf59f | |||
| 93680eb43d | 
| @@ -16,9 +16,9 @@ MAKEFLAGS += --no-builtin-rules | ||||
| ## LD := Linker. | ||||
| ## ANDROID_SDK := Path to the Android SDK. | ||||
|  | ||||
| VERSION_CODE := 43 | ||||
| VERSION_CODE_IOS := 17 | ||||
| VERSION_NUMBER := 0.2025.9 | ||||
| VERSION_CODE := 44 | ||||
| VERSION_CODE_IOS := 18 | ||||
| VERSION_NUMBER := 0.2025.10-wip | ||||
| VERSION_NAME := This program kills fascists. | ||||
|  | ||||
| IPHONEOS_VERSION_MIN=14.0 | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| { | ||||
| 	"type": "tildefriends-app", | ||||
| 	"emoji": "🦀", | ||||
| 	"previous": "&IDzjVQjtPyhesUrl45qkZFjzWl0xVlj+2M/XXQRvXO0=.sha256" | ||||
| 	"previous": "&01jXxJgs24zTcJk+csXeUWfm/MQ/+94Zy7K0r2OYmWw=.sha256" | ||||
| } | ||||
|   | ||||
| @@ -644,6 +644,35 @@ class TfMessageElement extends LitElement { | ||||
| 		return result; | ||||
| 	} | ||||
|  | ||||
| 	channel_group_by_author() { | ||||
| 		let sorted = this.message.messages | ||||
| 			.map((x) => [ | ||||
| 				x.author, | ||||
| 				x.content.subscribed ? 'subscribed to' : 'unsubscribed from', | ||||
| 				x.content.channel, | ||||
| 				x, | ||||
| 			]) | ||||
| 			.sort(); | ||||
| 		let result = []; | ||||
| 		let last; | ||||
| 		let group; | ||||
| 		for (let row of sorted) { | ||||
| 			if (last && last[0] == row[0] && last[1] == row[1]) { | ||||
| 				group.push(row[2]); | ||||
| 			} else { | ||||
| 				if (group) { | ||||
| 					result.push({author: last[0], action: last[1], channels: group}); | ||||
| 				} | ||||
| 				last = row; | ||||
| 				group = [row[2]]; | ||||
| 			} | ||||
| 		} | ||||
| 		if (group) { | ||||
| 			result.push({author: last[0], action: last[1], channels: group}); | ||||
| 		} | ||||
| 		return result; | ||||
| 	} | ||||
|  | ||||
| 	allow_unread() { | ||||
| 		return ( | ||||
| 			this.channel == '@' || | ||||
| @@ -719,6 +748,55 @@ class TfMessageElement extends LitElement { | ||||
| 					</button> | ||||
| 				`); | ||||
| 			} | ||||
| 		} else if (this.message?.type === 'channel_group') { | ||||
| 			if (this.expanded[this.expanded_key()]) { | ||||
| 				return this.render_frame(html` | ||||
| 					<div class="w3-padding"> | ||||
| 						${this.message.messages.map( | ||||
| 							(x) => | ||||
| 								html`<tf-message | ||||
| 									.message=${x} | ||||
| 									whoami=${this.whoami} | ||||
| 									.users=${this.users} | ||||
| 									.drafts=${this.drafts} | ||||
| 									.expanded=${this.expanded} | ||||
| 									channel=${this.channel} | ||||
| 									channel_unread=${this.channel_unread} | ||||
| 								></tf-message>` | ||||
| 						)} | ||||
| 					</div> | ||||
| 					<button | ||||
| 						class="w3-button w3-theme-d1 w3-block w3-bar" | ||||
| 						style="box-sizing: border-box" | ||||
| 						@click=${() => self.set_expanded(false)} | ||||
| 					> | ||||
| 						Collapse | ||||
| 					</button> | ||||
| 				`); | ||||
| 			} else { | ||||
| 				return this.render_frame(html` | ||||
| 					<div class="w3-padding"> | ||||
| 						${this.channel_group_by_author().map( | ||||
| 							(x) => html` | ||||
| 								<div> | ||||
| 									<tf-user id=${x.author} .users=${this.users}></tf-user> | ||||
| 									${x.action} | ||||
| 									${x.channels.map( | ||||
| 										(y) => html` <tf-tag tag=${'#' + y}></tf-tag> ` | ||||
| 									)} | ||||
| 								</div> | ||||
| 							` | ||||
| 						)} | ||||
| 					</div> | ||||
| 					<button | ||||
| 						class="w3-button w3-theme-d1 w3-block w3-bar" | ||||
| 						style="box-sizing: border-box" | ||||
| 						@click=${() => self.set_expanded(true)} | ||||
| 					> | ||||
| 						Expand | ||||
| 					</button> | ||||
| 				`); | ||||
| 			} | ||||
| 		} else if (this.message.placeholder) { | ||||
| 			return this.render_frame( | ||||
| 				html`<div> | ||||
|   | ||||
| @@ -160,11 +160,29 @@ class TfNewsElement extends LitElement { | ||||
| 		return recursive_sort(roots, true); | ||||
| 	} | ||||
|  | ||||
| 	group_following(messages) { | ||||
| 	group_messages(messages) { | ||||
| 		let result = []; | ||||
| 		let group = []; | ||||
| 		let type = undefined; | ||||
| 		for (let message of messages) { | ||||
| 			if (message?.content?.type === 'contact') { | ||||
| 			if ( | ||||
| 				message?.content?.type === 'contact' || | ||||
| 				message?.content?.type === 'channel' | ||||
| 			) { | ||||
| 				if (type && message.content.type !== type) { | ||||
| 					if (group.length == 1) { | ||||
| 						result.push(group[0]); | ||||
| 						group = []; | ||||
| 					} else if (group.length > 1) { | ||||
| 						result.push({ | ||||
| 							rowid: Math.max(...group.map((x) => x.rowid)), | ||||
| 							type: `${type}_group`, | ||||
| 							messages: group, | ||||
| 						}); | ||||
| 						group = []; | ||||
| 					} | ||||
| 				} | ||||
| 				type = message.content.type; | ||||
| 				group.push(message); | ||||
| 			} else { | ||||
| 				if (group.length == 1) { | ||||
| @@ -173,12 +191,13 @@ class TfNewsElement extends LitElement { | ||||
| 				} else if (group.length > 1) { | ||||
| 					result.push({ | ||||
| 						rowid: Math.max(...group.map((x) => x.rowid)), | ||||
| 						type: 'contact_group', | ||||
| 						type: `${type}_group`, | ||||
| 						messages: group, | ||||
| 					}); | ||||
| 					group = []; | ||||
| 				} | ||||
| 				result.push(message); | ||||
| 				type = undefined; | ||||
| 			} | ||||
| 		} | ||||
| 		if (group.length == 1) { | ||||
| @@ -187,7 +206,7 @@ class TfNewsElement extends LitElement { | ||||
| 		} else if (group.length > 1) { | ||||
| 			result.push({ | ||||
| 				rowid: Math.max(...group.map((x) => x.rowid)), | ||||
| 				type: 'contact_group', | ||||
| 				type: `${type}_group`, | ||||
| 				messages: group, | ||||
| 			}); | ||||
| 		} | ||||
| @@ -200,7 +219,7 @@ class TfNewsElement extends LitElement { | ||||
|  | ||||
| 	load_and_render(messages) { | ||||
| 		let messages_by_id = this.process_messages(messages); | ||||
| 		let final_messages = this.group_following( | ||||
| 		let final_messages = this.group_messages( | ||||
| 			this.finalize_messages(messages_by_id) | ||||
| 		); | ||||
| 		let unread_rowid = -1; | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| { | ||||
| 	"type": "tildefriends-app", | ||||
| 	"emoji": "👋", | ||||
| 	"previous": "&5NkMRSgcMqCYF3xcLOBmaytkoxfV9zx4br7JladKPTs=.sha256" | ||||
| 	"previous": "&ijyL/pyTwguBd9njagU7Vpc/1EyRermZuzrlq1mnzbY=.sha256" | ||||
| } | ||||
|   | ||||
| @@ -104,7 +104,7 @@ | ||||
| 												src="googleplay.svg" | ||||
| 												style="height: 2em; margin: 0" | ||||
| 											/> | ||||
| 											Get it on Google Play (Open Testing) | ||||
| 											Get it on Google Play | ||||
| 										</a> | ||||
| 										<a | ||||
| 											class="w3-button w3-round-large w3-padding w3-blue-gray w3-margin-top" | ||||
| @@ -298,7 +298,7 @@ | ||||
|  | ||||
| 		<!-- Technlology Section --> | ||||
| 		<div class="w3-container w3-padding-64 w3-light-grey w3-center"> | ||||
| 			<h1 class="w3-jumbo"><b>Built the Old Fashioned Way</b></h1> | ||||
| 			<h1 class="w3-jumbo"><b>Built to Last</b></h1> | ||||
| 			<p> | ||||
| 				Tilde Friends strives to use only simple and widely adopted dependencies | ||||
| 				in order to keep it easy to build for all sorts of platforms and | ||||
|   | ||||
| @@ -25,14 +25,14 @@ | ||||
| }: | ||||
| pkgs.stdenv.mkDerivation rec { | ||||
|   pname = "tildefriends"; | ||||
|   version = "0.2025.8"; | ||||
|   version = "0.2025.9"; | ||||
|  | ||||
|   src = pkgs.fetchFromGitea { | ||||
|     domain = "dev.tildefriends.net"; | ||||
|     owner = "cory"; | ||||
|     repo = "tildefriends"; | ||||
|     rev = "v${version}"; | ||||
|     hash = "sha256-N/5lp8RL19B6Z43kRxx7c01WVJkK44a/wwNgRJPk5uI="; | ||||
|     hash = "sha256-1nhsfhdOO5HIiiTMb+uROB8nDPL/UpOYm52hZ/OpPyk="; | ||||
|     fetchSubmodules = true; | ||||
|   }; | ||||
|  | ||||
|   | ||||
							
								
								
									
										6
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										6
									
								
								flake.lock
									
									
									
										generated
									
									
									
								
							| @@ -20,11 +20,11 @@ | ||||
|     }, | ||||
|     "nixpkgs": { | ||||
|       "locked": { | ||||
|         "lastModified": 1756217674, | ||||
|         "narHash": "sha256-TH1SfSP523QI7kcPiNtMAEuwZR3Jdz0MCDXPs7TS8uo=", | ||||
|         "lastModified": 1758589230, | ||||
|         "narHash": "sha256-zMTCFGe8aVGTEr2RqUi/QzC1nOIQ0N1HRsbqB4f646k=", | ||||
|         "owner": "NixOS", | ||||
|         "repo": "nixpkgs", | ||||
|         "rev": "4e7667a90c167f7a81d906e5a75cba4ad8bee620", | ||||
|         "rev": "d1d883129b193f0b495d75c148c2c3a7d95789a0", | ||||
|         "type": "github" | ||||
|       }, | ||||
|       "original": { | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| <?xml version="1.0" encoding="utf-8"?> | ||||
| <manifest xmlns:android="http://schemas.android.com/apk/res/android" | ||||
| 	package="com.unprompted.tildefriends" | ||||
| 	android:versionCode="43" | ||||
| 	android:versionName="0.2025.9"> | ||||
| 	android:versionCode="44" | ||||
| 	android:versionName="0.2025.10-wip"> | ||||
| 	<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/> | ||||
| 	<uses-permission android:name="android.permission.INTERNET"/> | ||||
| 	<application | ||||
|   | ||||
| @@ -13,13 +13,13 @@ | ||||
| 	<key>CFBundlePackageType</key> | ||||
| 	<string>APPL</string> | ||||
| 	<key>CFBundleShortVersionString</key> | ||||
| 	<string>0.2025.9</string> | ||||
| 	<string>0.2025.10</string> | ||||
| 	<key>CFBundleSupportedPlatforms</key> | ||||
| 	<array> | ||||
| 		<string>iPhoneOS</string> | ||||
| 	</array> | ||||
| 	<key>CFBundleVersion</key> | ||||
| 	<string>17</string> | ||||
| 	<string>18</string> | ||||
| 	<key>DTPlatformName</key> | ||||
| 	<string>iphoneos</string> | ||||
| 	<key>LSRequiresIPhoneOS</key> | ||||
|   | ||||
| @@ -1,2 +1,2 @@ | ||||
| #define VERSION_NUMBER "0.2025.9" | ||||
| #define VERSION_NUMBER "0.2025.10-wip" | ||||
| #define VERSION_NAME "This program kills fascists." | ||||
|   | ||||
		Reference in New Issue
	
	Block a user