mirror of
				https://github.com/maunium/stickerpicker
				synced 2025-10-25 17:28:10 +00:00 
			
		
		
		
	Compare commits
	
		
			5 Commits
		
	
	
		
			4208d495ed
			...
			1b6d5a97d9
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 1b6d5a97d9 | ||
|  | f545606bf1 | ||
|  | 0c70fad5c3 | ||
|  | d14271d036 | ||
|  | ca99c5f00d | 
| @ -55,12 +55,18 @@ async def load_config(path: str) -> None: | |||||||
|             config = json.load(config_file) |             config = json.load(config_file) | ||||||
|             homeserver_url = config["homeserver"] |             homeserver_url = config["homeserver"] | ||||||
|             access_token = config["access_token"] |             access_token = config["access_token"] | ||||||
|  |             try: | ||||||
|                 giphy_api_key = config["giphy_api_key"] |                 giphy_api_key = config["giphy_api_key"] | ||||||
|  |                 giphy_mxc_prefix = config["giphy_mxc_prefix"] | ||||||
|  |             except KeyError: | ||||||
|  |                 # these two are not mandatory, assume GIF search is disabled | ||||||
|  |                 print("Giphy related parameters not found in the config file.") | ||||||
|     except FileNotFoundError: |     except FileNotFoundError: | ||||||
|         print("Matrix config file not found. Please enter your homeserver and access token. Enter the Giphy API token if required, leave blank to disable the gif picker.") |         print("Matrix config file not found. Please enter your homeserver and access token. Enter the Giphy API token if required, leave blank to disable the gif picker.") | ||||||
|         homeserver_url = input("Homeserver URL: ") |         homeserver_url = input("Homeserver URL: ") | ||||||
|         access_token = input("Access token: ") |         access_token = input("Access token: ") | ||||||
|         giphy_api_key = input("Giphy API key: ") |         giphy_api_key = input("Giphy API key: ") | ||||||
|  |         giphy_mxc_prefix = input("Giphy MXC prefix. Defaults to 'mxc://giphy.mau.dev/', required to proxy GIFs: ") | ||||||
|         whoami_url = URL(homeserver_url) / "_matrix" / "client" / "r0" / "account" / "whoami" |         whoami_url = URL(homeserver_url) / "_matrix" / "client" / "r0" / "account" / "whoami" | ||||||
|         if whoami_url.scheme not in ("https", "http"): |         if whoami_url.scheme not in ("https", "http"): | ||||||
|             whoami_url = whoami_url.with_scheme("https") |             whoami_url = whoami_url.with_scheme("https") | ||||||
| @ -70,7 +76,8 @@ async def load_config(path: str) -> None: | |||||||
|                 "homeserver": homeserver_url, |                 "homeserver": homeserver_url, | ||||||
|                 "user_id": user_id, |                 "user_id": user_id, | ||||||
|                 "access_token": access_token, |                 "access_token": access_token, | ||||||
|                 "giphy_api_key": giphy_api_key |                 "giphy_api_key": giphy_api_key, | ||||||
|  |                 "giphy_mxc_prefix": giphy_mxc_prefix, | ||||||
|             }, config_file) |             }, config_file) | ||||||
|         print(f"Wrote config to {path}") |         print(f"Wrote config to {path}") | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,6 +1 @@ | |||||||
| # Generated in setup.py | from .get_version import git_tag, git_revision, version, linkified_version | ||||||
| 
 |  | ||||||
| git_tag = None |  | ||||||
| git_revision = 'f59406a4' |  | ||||||
| version = '0.1.0+dev.f59406a4' |  | ||||||
| linkified_version = '0.1.0+dev.[f59406a4](https://github.com/maunium/stickerpicker/commit/f59406a47a6778cd402e656ffb64f667335f665a)' |  | ||||||
|  | |||||||
| @ -4,8 +4,7 @@ | |||||||
|     <meta charset="utf-8"> |     <meta charset="utf-8"> | ||||||
|     <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no, user-scalable=no"> |     <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no, user-scalable=no"> | ||||||
|     <title>Maunium sticker picker</title> |     <title>Maunium sticker picker</title> | ||||||
|     <script src="https://unpkg.com/matrix-widget-api@1.6.0/dist/api.js"></script> |     <link rel="modulepreload" href="src/widget-api.js"/> | ||||||
|     <script type="module" src="src/widget-api.js"></script> |  | ||||||
|     <link rel="modulepreload" href="src/frequently-used.js"/> |     <link rel="modulepreload" href="src/frequently-used.js"/> | ||||||
|     <link rel="modulepreload" href="src/spinner.js"/> |     <link rel="modulepreload" href="src/spinner.js"/> | ||||||
|     <link rel="modulepreload" href="lib/htm/preact.js"/> |     <link rel="modulepreload" href="lib/htm/preact.js"/> | ||||||
|  | |||||||
| @ -1,16 +0,0 @@ | |||||||
| { |  | ||||||
|   "packs": [ |  | ||||||
|       "scalar-isabella.json", |  | ||||||
|       "scalar-privacy_pam.json", |  | ||||||
|       "scalar-sheltie.json", |  | ||||||
|       "scalar-stakey.json", |  | ||||||
|       "scalar-videoplasty.json", |  | ||||||
|       "scalar-geeko.json", |  | ||||||
|       "scalar-loading_artist.json", |  | ||||||
|       "scalar-rabbit.json", |  | ||||||
|       "scalar-smilies.json", |  | ||||||
|       "scalar-stickman.json" |  | ||||||
|   ], |  | ||||||
|   "homeserver_url": "https://matrix.intothematrix.in", |  | ||||||
|   "giphy_api_key": "Gc7131jiJuvI7IdN0HZ1D7nh0ow5BU6g" |  | ||||||
| } |  | ||||||
| @ -1 +0,0 @@ | |||||||
| {"title": "Geeko", "id": "scalar-191580", "stickers": [{"body": "Geeko with a suitcase, wearing a suit", "info": {"h": 256, "mimetype": "image/png", "size": 41241, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 41241, "w": 256}, "thumbnail_url": "mxc://matrix.org/GWyQoBKgXAoIXhBcCMCxmkxd", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/GWyQoBKgXAoIXhBcCMCxmkxd", "id": "GWyQoBKgXAoIXhBcCMCxmkxd"}, {"body": "Geeko driving away in a car waving", "info": {"h": 256, "mimetype": "image/png", "size": 51387, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 51387, "w": 256}, "thumbnail_url": "mxc://matrix.org/JkAPbbuIuOMMbWqhKTNnGETu", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/JkAPbbuIuOMMbWqhKTNnGETu", "id": "JkAPbbuIuOMMbWqhKTNnGETu"}, {"body": "Geeko enjoying his time in an armchair with a cup of tea", "info": {"h": 256, "mimetype": "image/png", "size": 44188, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 44188, "w": 256}, "thumbnail_url": "mxc://matrix.org/AdkCycKHKGfgpyOCrlcSihDK", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/AdkCycKHKGfgpyOCrlcSihDK", "id": "AdkCycKHKGfgpyOCrlcSihDK"}, {"body": "Sick Geeko wrapped in a blanket with a tray of refreshing bevarage", "info": {"h": 256, "mimetype": "image/png", "size": 36364, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 36364, "w": 256}, "thumbnail_url": "mxc://matrix.org/SNkQWaqBkKwIEHQyJmAuhnIL", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/SNkQWaqBkKwIEHQyJmAuhnIL", "id": "SNkQWaqBkKwIEHQyJmAuhnIL"}, {"body": "Geeko in a balerina skirt inviting to dance with them", "info": {"h": 256, "mimetype": "image/png", "size": 34716, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 34716, "w": 256}, "thumbnail_url": "mxc://matrix.org/WLjGVDOlqAPtMaggqcgmjZsB", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/WLjGVDOlqAPtMaggqcgmjZsB", "id": "WLjGVDOlqAPtMaggqcgmjZsB"}, {"body": "Geeko laying on a cloud", "info": {"h": 256, "mimetype": "image/png", "size": 39189, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 39189, "w": 256}, "thumbnail_url": "mxc://matrix.org/ouaitVRUeqIJCuMuKLNtzOPl", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/ouaitVRUeqIJCuMuKLNtzOPl", "id": "ouaitVRUeqIJCuMuKLNtzOPl"}, {"body": "Geeko stretching", "info": {"h": 256, "mimetype": "image/png", "size": 34670, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 34670, "w": 256}, "thumbnail_url": "mxc://matrix.org/DXEyavdgypGEPLeWdmaAkOAG", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/DXEyavdgypGEPLeWdmaAkOAG", "id": "DXEyavdgypGEPLeWdmaAkOAG"}, {"body": "Geeko aproaching Nirvana", "info": {"h": 256, "mimetype": "image/png", "size": 42035, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 42035, "w": 256}, "thumbnail_url": "mxc://matrix.org/DRCkchiNQgASUCFTxFDDfhvi", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/DRCkchiNQgASUCFTxFDDfhvi", "id": "DRCkchiNQgASUCFTxFDDfhvi"}, {"body": "Geeko dressed in a paper airplane, running", "info": {"h": 256, "mimetype": "image/png", "size": 49568, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 49568, "w": 256}, "thumbnail_url": "mxc://matrix.org/YrJQDfZpESKIYdUzvhMDXBLU", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/YrJQDfZpESKIYdUzvhMDXBLU", "id": "YrJQDfZpESKIYdUzvhMDXBLU"}, {"body": "Geeko drawing an animal", "info": {"h": 256, "mimetype": "image/png", "size": 54112, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 54112, "w": 256}, "thumbnail_url": "mxc://matrix.org/bHmdDCDjmolEjrxAFDGuHoJa", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/bHmdDCDjmolEjrxAFDGuHoJa", "id": "bHmdDCDjmolEjrxAFDGuHoJa"}]} |  | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -1 +0,0 @@ | |||||||
| {"title": "Privacy Pam", "id": "scalar-191583", "stickers": [{"body": "Privacy Pam is Angry", "info": {"h": 256, "mimetype": "image/png", "size": 184861, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 184861, "w": 256}, "thumbnail_url": "mxc://matrix.org/WYZLGkpAXwgOftafRtSQVNYF", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/WYZLGkpAXwgOftafRtSQVNYF", "id": "WYZLGkpAXwgOftafRtSQVNYF"}, {"body": "Privacy Pam Cries", "info": {"h": 256, "mimetype": "image/png", "size": 164740, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 164740, "w": 256}, "thumbnail_url": "mxc://matrix.org/aVOIYKvTRBiKqZbxomKeuwYD", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/aVOIYKvTRBiKqZbxomKeuwYD", "id": "aVOIYKvTRBiKqZbxomKeuwYD"}, {"body": "Privacy Pam is Happy", "info": {"h": 256, "mimetype": "image/png", "size": 172907, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 172907, "w": 256}, "thumbnail_url": "mxc://matrix.org/FZolsrwTDUJoLlGfWHffwuFP", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/FZolsrwTDUJoLlGfWHffwuFP", "id": "FZolsrwTDUJoLlGfWHffwuFP"}, {"body": "Privacy Pam Laughs", "info": {"h": 256, "mimetype": "image/png", "size": 170855, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 170855, "w": 256}, "thumbnail_url": "mxc://matrix.org/qTfporLEnxtdkdwmPUQwWNtg", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/qTfporLEnxtdkdwmPUQwWNtg", "id": "qTfporLEnxtdkdwmPUQwWNtg"}, {"body": "Privacy Pam is Sad", "info": {"h": 256, "mimetype": "image/png", "size": 179575, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 179575, "w": 256}, "thumbnail_url": "mxc://matrix.org/MvUDjTTYKanEzFAExAhJfyAL", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/MvUDjTTYKanEzFAExAhJfyAL", "id": "MvUDjTTYKanEzFAExAhJfyAL"}, {"body": "Privacy Pam Smiles", "info": {"h": 256, "mimetype": "image/png", "size": 185764, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 185764, "w": 256}, "thumbnail_url": "mxc://matrix.org/cUbyqEDvdvxMqnfBGKmIpgfp", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/cUbyqEDvdvxMqnfBGKmIpgfp", "id": "cUbyqEDvdvxMqnfBGKmIpgfp"}, {"body": "Privacy Pam is Thinking", "info": {"h": 256, "mimetype": "image/png", "size": 199567, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 199567, "w": 256}, "thumbnail_url": "mxc://matrix.org/JnxtjVDYQHKGMWDRqSDgCwPL", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/JnxtjVDYQHKGMWDRqSDgCwPL", "id": "JnxtjVDYQHKGMWDRqSDgCwPL"}, {"body": "Privacy Pam Likes", "info": {"h": 256, "mimetype": "image/png", "size": 196924, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 196924, "w": 256}, "thumbnail_url": "mxc://matrix.org/umFLoIIzwirpWpcbnlgbtNNW", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/umFLoIIzwirpWpcbnlgbtNNW", "id": "umFLoIIzwirpWpcbnlgbtNNW"}, {"body": "Privacy Pam Winks", "info": {"h": 256, "mimetype": "image/png", "size": 167280, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 167280, "w": 256}, "thumbnail_url": "mxc://matrix.org/mehuoFXMMUdUSezwTwkkxHCB", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/mehuoFXMMUdUSezwTwkkxHCB", "id": "mehuoFXMMUdUSezwTwkkxHCB"}]} |  | ||||||
| @ -1 +0,0 @@ | |||||||
| {"title": "Rabbit", "id": "scalar-191566", "stickers": [{"body": "Carrot", "info": {"h": 200, "mimetype": "image/png", "size": 80625, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 80625, "w": 142}, "thumbnail_url": "mxc://matrix.org/kGJDCjMOgpLmZzbgknMTUHNm", "w": 142}, "msgtype": "m.sticker", "url": "mxc://matrix.org/kGJDCjMOgpLmZzbgknMTUHNm", "id": "kGJDCjMOgpLmZzbgknMTUHNm"}, {"body": "Chef", "info": {"h": 200, "mimetype": "image/png", "size": 88633, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 88633, "w": 151}, "thumbnail_url": "mxc://matrix.org/szaTExsJurtDBUUEeHHbhyqk", "w": 151}, "msgtype": "m.sticker", "url": "mxc://matrix.org/szaTExsJurtDBUUEeHHbhyqk", "id": "szaTExsJurtDBUUEeHHbhyqk"}, {"body": "Coding", "info": {"h": 185, "mimetype": "image/png", "size": 97412, "thumbnail_info": {"h": 185, "mimetype": "image/png", "size": 97412, "w": 200}, "thumbnail_url": "mxc://matrix.org/DykipVHRXsfamLGJscNLbFAB", "w": 200}, "msgtype": "m.sticker", "url": "mxc://matrix.org/DykipVHRXsfamLGJscNLbFAB", "id": "DykipVHRXsfamLGJscNLbFAB"}, {"body": "Doctor", "info": {"h": 200, "mimetype": "image/png", "size": 113391, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 113391, "w": 184}, "thumbnail_url": "mxc://matrix.org/GEhjrKIapqcbVWKEsoDMhXeZ", "w": 184}, "msgtype": "m.sticker", "url": "mxc://matrix.org/GEhjrKIapqcbVWKEsoDMhXeZ", "id": "GEhjrKIapqcbVWKEsoDMhXeZ"}, {"body": "Driving", "info": {"h": 200, "mimetype": "image/png", "size": 77577, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 77577, "w": 156}, "thumbnail_url": "mxc://matrix.org/jxPXTKpyydzdHJkdFNZjTZrD", "w": 156}, "msgtype": "m.sticker", "url": "mxc://matrix.org/jxPXTKpyydzdHJkdFNZjTZrD", "id": "jxPXTKpyydzdHJkdFNZjTZrD"}, {"body": "Landing", "info": {"h": 200, "mimetype": "image/png", "size": 73602, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 73602, "w": 140}, "thumbnail_url": "mxc://matrix.org/sHhqkFCvSkFwtmvtETOtKnLP", "w": 140}, "msgtype": "m.sticker", "url": "mxc://matrix.org/sHhqkFCvSkFwtmvtETOtKnLP", "id": "sHhqkFCvSkFwtmvtETOtKnLP"}, {"body": "Phone", "info": {"h": 200, "mimetype": "image/png", "size": 94007, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 94007, "w": 172}, "thumbnail_url": "mxc://matrix.org/mnNNbLjjLjQIcKaybAyVMKMQ", "w": 172}, "msgtype": "m.sticker", "url": "mxc://matrix.org/mnNNbLjjLjQIcKaybAyVMKMQ", "id": "mnNNbLjjLjQIcKaybAyVMKMQ"}, {"body": "Running", "info": {"h": 157, "mimetype": "image/png", "size": 83290, "thumbnail_info": {"h": 157, "mimetype": "image/png", "size": 83290, "w": 200}, "thumbnail_url": "mxc://matrix.org/gloPNMnAwUEtrtTsaeqPTlhK", "w": 200}, "msgtype": "m.sticker", "url": "mxc://matrix.org/gloPNMnAwUEtrtTsaeqPTlhK", "id": "gloPNMnAwUEtrtTsaeqPTlhK"}, {"body": "Science", "info": {"h": 200, "mimetype": "image/png", "size": 103111, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 103111, "w": 155}, "thumbnail_url": "mxc://matrix.org/uDmIFKTXYQpzipNELqRhWSsj", "w": 155}, "msgtype": "m.sticker", "url": "mxc://matrix.org/uDmIFKTXYQpzipNELqRhWSsj", "id": "uDmIFKTXYQpzipNELqRhWSsj"}, {"body": "Work", "info": {"h": 150, "mimetype": "image/png", "size": 81850, "thumbnail_info": {"h": 150, "mimetype": "image/png", "size": 81850, "w": 200}, "thumbnail_url": "mxc://matrix.org/kYOcGZCqtNzBSUqBBOaLDBgE", "w": 200}, "msgtype": "m.sticker", "url": "mxc://matrix.org/kYOcGZCqtNzBSUqBBOaLDBgE", "id": "kYOcGZCqtNzBSUqBBOaLDBgE"}]} |  | ||||||
| @ -1 +0,0 @@ | |||||||
| {"title": "Sheltie", "id": "scalar-192093", "stickers": [{"body": "Busy", "info": {"h": 173, "mimetype": "image/png", "size": 132161, "thumbnail_info": {"h": 173, "mimetype": "image/png", "size": 132161, "w": 200}, "thumbnail_url": "mxc://matrix.org/KbQyHYcnRFPSfRCbGqbTBiWt", "w": 200}, "msgtype": "m.sticker", "url": "mxc://matrix.org/KbQyHYcnRFPSfRCbGqbTBiWt", "id": "KbQyHYcnRFPSfRCbGqbTBiWt"}, {"body": "Confused", "info": {"h": 200, "mimetype": "image/png", "size": 111042, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 111042, "w": 173}, "thumbnail_url": "mxc://matrix.org/KkCmAbAPsgeUFdOyOceqAFBr", "w": 173}, "msgtype": "m.sticker", "url": "mxc://matrix.org/KkCmAbAPsgeUFdOyOceqAFBr", "id": "KkCmAbAPsgeUFdOyOceqAFBr"}, {"body": "Happy", "info": {"h": 158, "mimetype": "image/png", "size": 110679, "thumbnail_info": {"h": 158, "mimetype": "image/png", "size": 110679, "w": 200}, "thumbnail_url": "mxc://matrix.org/gFrdGIZbVATfwziAHnIYwEuh", "w": 200}, "msgtype": "m.sticker", "url": "mxc://matrix.org/gFrdGIZbVATfwziAHnIYwEuh", "id": "gFrdGIZbVATfwziAHnIYwEuh"}, {"body": "Hungry", "info": {"h": 183, "mimetype": "image/png", "size": 97642, "thumbnail_info": {"h": 183, "mimetype": "image/png", "size": 97642, "w": 200}, "thumbnail_url": "mxc://matrix.org/LWtWooRvIbhgLjQPPtyhWNgP", "w": 200}, "msgtype": "m.sticker", "url": "mxc://matrix.org/LWtWooRvIbhgLjQPPtyhWNgP", "id": "LWtWooRvIbhgLjQPPtyhWNgP"}, {"body": "Innocent", "info": {"h": 200, "mimetype": "image/png", "size": 107331, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 107331, "w": 186}, "thumbnail_url": "mxc://matrix.org/IItfiFhKoPieFyPLceBLcFhd", "w": 186}, "msgtype": "m.sticker", "url": "mxc://matrix.org/IItfiFhKoPieFyPLceBLcFhd", "id": "IItfiFhKoPieFyPLceBLcFhd"}, {"body": "Laughing", "info": {"h": 200, "mimetype": "image/png", "size": 118620, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 118620, "w": 194}, "thumbnail_url": "mxc://matrix.org/LxEPZAsPAfjyRfAwpYSoIxwV", "w": 194}, "msgtype": "m.sticker", "url": "mxc://matrix.org/LxEPZAsPAfjyRfAwpYSoIxwV", "id": "LxEPZAsPAfjyRfAwpYSoIxwV"}, {"body": "Sad", "info": {"h": 200, "mimetype": "image/png", "size": 104622, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 104622, "w": 177}, "thumbnail_url": "mxc://matrix.org/MjdsQxPFskrLFQfXHFuJrwbr", "w": 177}, "msgtype": "m.sticker", "url": "mxc://matrix.org/MjdsQxPFskrLFQfXHFuJrwbr", "id": "MjdsQxPFskrLFQfXHFuJrwbr"}, {"body": "Sleepy", "info": {"h": 200, "mimetype": "image/png", "size": 116609, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 116609, "w": 196}, "thumbnail_url": "mxc://matrix.org/iqEhhOuswzPITADcrmQZPxbh", "w": 196}, "msgtype": "m.sticker", "url": "mxc://matrix.org/iqEhhOuswzPITADcrmQZPxbh", "id": "iqEhhOuswzPITADcrmQZPxbh"}, {"body": "Thank-you", "info": {"h": 200, "mimetype": "image/png", "size": 109865, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 109865, "w": 160}, "thumbnail_url": "mxc://matrix.org/qnyciftjKPqVDyEIjcakwCUO", "w": 160}, "msgtype": "m.sticker", "url": "mxc://matrix.org/qnyciftjKPqVDyEIjcakwCUO", "id": "qnyciftjKPqVDyEIjcakwCUO"}, {"body": "Thumb-up", "info": {"h": 200, "mimetype": "image/png", "size": 120744, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 120744, "w": 184}, "thumbnail_url": "mxc://matrix.org/xHCAaOqwMjyJYQMHIFIgeryn", "w": 184}, "msgtype": "m.sticker", "url": "mxc://matrix.org/xHCAaOqwMjyJYQMHIFIgeryn", "id": "xHCAaOqwMjyJYQMHIFIgeryn"}]} |  | ||||||
| @ -1 +0,0 @@ | |||||||
| {"title": "Smilies", "id": "scalar-192094", "stickers": [{"body": "I'm really angry!", "info": {"h": 256, "mimetype": "image/png", "size": 20840, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 20840, "w": 256}, "thumbnail_url": "mxc://matrix.org/vjgWJdgaAdPLYJMsAjbJrOIa", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/vjgWJdgaAdPLYJMsAjbJrOIa", "id": "vjgWJdgaAdPLYJMsAjbJrOIa"}, {"body": "I'm dead tired", "info": {"h": 256, "mimetype": "image/png", "size": 20143, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 20143, "w": 256}, "thumbnail_url": "mxc://matrix.org/GAZUrYmcYRtcNofjGGqAWhqI", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/GAZUrYmcYRtcNofjGGqAWhqI", "id": "GAZUrYmcYRtcNofjGGqAWhqI"}, {"body": "I'm really happy", "info": {"h": 256, "mimetype": "image/png", "size": 20509, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 20509, "w": 256}, "thumbnail_url": "mxc://matrix.org/SthCvLTenNJopFCEzEeZEwJy", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/SthCvLTenNJopFCEzEeZEwJy", "id": "SthCvLTenNJopFCEzEeZEwJy"}, {"body": "Friday I'm in love!", "info": {"h": 256, "mimetype": "image/png", "size": 20726, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 20726, "w": 256}, "thumbnail_url": "mxc://matrix.org/sCpzSdxGKNVTyyaaTtDvKIVw", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/sCpzSdxGKNVTyyaaTtDvKIVw", "id": "sCpzSdxGKNVTyyaaTtDvKIVw"}, {"body": "Show me the money!", "info": {"h": 256, "mimetype": "image/png", "size": 20852, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 20852, "w": 256}, "thumbnail_url": "mxc://matrix.org/RPsEdZjVSCdxklObGMzyeUBm", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/RPsEdZjVSCdxklObGMzyeUBm", "id": "RPsEdZjVSCdxklObGMzyeUBm"}, {"body": "I'm just sad", "info": {"h": 256, "mimetype": "image/png", "size": 22825, "thumbnail_info": {"h": 256, "mimetype": "image/png", "size": 22825, "w": 256}, "thumbnail_url": "mxc://matrix.org/RseXEsYHhkmmiGCzKYDuFyZt", "w": 256}, "msgtype": "m.sticker", "url": "mxc://matrix.org/RseXEsYHhkmmiGCzKYDuFyZt", "id": "RseXEsYHhkmmiGCzKYDuFyZt"}]} |  | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -1 +0,0 @@ | |||||||
| {"title": "Stickman", "id": "scalar-192096", "stickers": [{"body": "A hastily-rendered stick figure stares at you blankly. Its arms are folded: perhaps defensively, perhaps in a half-hearted Gangnam Style.", "info": {"h": 200, "mimetype": "image/png", "size": 28154, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 28154, "w": 106}, "thumbnail_url": "mxc://matrix.org/bQGEpjrZQcWLgygXmuaJCNNA", "w": 106}, "msgtype": "m.sticker", "url": "mxc://matrix.org/bQGEpjrZQcWLgygXmuaJCNNA", "id": "bQGEpjrZQcWLgygXmuaJCNNA"}, {"body": "Question marks of varying sizes orbit a stick figure's head.", "info": {"h": 194, "mimetype": "image/png", "size": 95200, "thumbnail_info": {"h": 194, "mimetype": "image/png", "size": 95200, "w": 200}, "thumbnail_url": "mxc://matrix.org/aVdcZtGRijWluoSjCAytBHnP", "w": 200}, "msgtype": "m.sticker", "url": "mxc://matrix.org/aVdcZtGRijWluoSjCAytBHnP", "id": "aVdcZtGRijWluoSjCAytBHnP"}, {"body": "A hastily-rendered stick figure stands with arms outstretched, smiling, beneath the word 'HOORAY' in an arc above its head. The figure is smiling in celebration.", "info": {"h": 200, "mimetype": "image/png", "size": 27199, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 27199, "w": 142}, "thumbnail_url": "mxc://matrix.org/BMcDXCuQjoAaWvlPBlUjXBNa", "w": 142}, "msgtype": "m.sticker", "url": "mxc://matrix.org/BMcDXCuQjoAaWvlPBlUjXBNa", "id": "BMcDXCuQjoAaWvlPBlUjXBNa"}, {"body": "A hastily-rendered stick figure stands with arms in the air beneath three blue-and-white juggling balls apparently in motion. We cannot tell whether the figure is juggling competently or has simply thrown all three balls into the air and is awaiting the inevitable. The figure's mouth is formed into an enigmatic 'o'.", "info": {"h": 200, "mimetype": "image/png", "size": 30170, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 30170, "w": 88}, "thumbnail_url": "mxc://matrix.org/mQEotjwsEKeZivqIfZjxNfgC", "w": 88}, "msgtype": "m.sticker", "url": "mxc://matrix.org/mQEotjwsEKeZivqIfZjxNfgC", "id": "mQEotjwsEKeZivqIfZjxNfgC"}, {"body": "A hastily-rendered stick figure is thinking about lunch. Shouldn't you be thinking about lunch?", "info": {"h": 187, "mimetype": "image/png", "size": 55105, "thumbnail_info": {"h": 187, "mimetype": "image/png", "size": 55105, "w": 200}, "thumbnail_url": "mxc://matrix.org/ZHGncPEBowOpxqbVYCGbBTff", "w": 200}, "msgtype": "m.sticker", "url": "mxc://matrix.org/ZHGncPEBowOpxqbVYCGbBTff", "id": "ZHGncPEBowOpxqbVYCGbBTff"}, {"body": "A hastily-rendered stick figure stands with arms outstretched, smiling.", "info": {"h": 200, "mimetype": "image/png", "size": 26585, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 26585, "w": 138}, "thumbnail_url": "mxc://matrix.org/FGCzIxIKpswOIJCWZUWlCoKi", "w": 138}, "msgtype": "m.sticker", "url": "mxc://matrix.org/FGCzIxIKpswOIJCWZUWlCoKi", "id": "FGCzIxIKpswOIJCWZUWlCoKi"}, {"body": "A hastily-rendered stick figure stands holding a placard which reads 'I HAVE OPINIONS'. The figure's mouth is wide and angry, suggesting said opinions might not be the same as yours.", "info": {"h": 200, "mimetype": "image/png", "size": 45505, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 45505, "w": 139}, "thumbnail_url": "mxc://matrix.org/eSdUNjchqskXmCOiLgjqsakm", "w": 139}, "msgtype": "m.sticker", "url": "mxc://matrix.org/eSdUNjchqskXmCOiLgjqsakm", "id": "eSdUNjchqskXmCOiLgjqsakm"}, {"body": "A hastily-rendered stick figure stands with arms in the air. The figure's mouth is formed into an enigmatic 'o'.", "info": {"h": 200, "mimetype": "image/png", "size": 25059, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 25059, "w": 132}, "thumbnail_url": "mxc://matrix.org/puRSMGiaBfdAwYzfdHQFiJMJ", "w": 132}, "msgtype": "m.sticker", "url": "mxc://matrix.org/puRSMGiaBfdAwYzfdHQFiJMJ", "id": "puRSMGiaBfdAwYzfdHQFiJMJ"}, {"body": "A hastily-rendered stick figure has put on its robe and wizard hat.", "info": {"h": 200, "mimetype": "image/png", "size": 43579, "thumbnail_info": {"h": 200, "mimetype": "image/png", "size": 43579, "w": 108}, "thumbnail_url": "mxc://matrix.org/aplWcQPboleenDWMurAdHpHb", "w": 108}, "msgtype": "m.sticker", "url": "mxc://matrix.org/aplWcQPboleenDWMurAdHpHb", "id": "aplWcQPboleenDWMurAdHpHb"}]} |  | ||||||
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| @ -32,6 +32,7 @@ if (params.has('config')) { | |||||||
| // This is updated from packs/index.json
 | // This is updated from packs/index.json
 | ||||||
| let HOMESERVER_URL = "https://matrix-client.matrix.org" | let HOMESERVER_URL = "https://matrix-client.matrix.org" | ||||||
| let GIPHY_API_KEY = "" | let GIPHY_API_KEY = "" | ||||||
|  | let GIPHY_MXC_PREFIX = "mxc://giphy.mau.dev/" | ||||||
| 
 | 
 | ||||||
| const makeThumbnailURL = mxc => `${HOMESERVER_URL}/_matrix/media/r0/thumbnail/${mxc.substr(6)}?height=128&width=128&method=scale` | const makeThumbnailURL = mxc => `${HOMESERVER_URL}/_matrix/media/r0/thumbnail/${mxc.substr(6)}?height=128&width=128&method=scale` | ||||||
| 
 | 
 | ||||||
| @ -67,8 +68,8 @@ class GiphySearchTab extends Component { | |||||||
|   async searchGifs() { |   async searchGifs() { | ||||||
|     this.setState({ loading: true }); |     this.setState({ loading: true }); | ||||||
|     try { |     try { | ||||||
|     // const apiKey = "Gc7131jiJuvI7IdN0HZ1D7nh0ow5BU6g";
 |  | ||||||
|     const apiKey = GIPHY_API_KEY; |     const apiKey = GIPHY_API_KEY; | ||||||
|  |     const mxc_prefix = GIPHY_MXC_PREFIX; | ||||||
|     const url = `https://api.giphy.com/v1/gifs/search?q=${this.state.searchTerm}&api_key=${apiKey}`; |     const url = `https://api.giphy.com/v1/gifs/search?q=${this.state.searchTerm}&api_key=${apiKey}`; | ||||||
|     this.setState({ loading: true }); |     this.setState({ loading: true }); | ||||||
|     const response = await fetch(url); |     const response = await fetch(url); | ||||||
| @ -82,17 +83,10 @@ class GiphySearchTab extends Component { | |||||||
|                 "h": jsonElement.images.original.height, |                 "h": jsonElement.images.original.height, | ||||||
|                 "w": jsonElement.images.original.width, |                 "w": jsonElement.images.original.width, | ||||||
|                 "size": jsonElement.images.original.size, |                 "size": jsonElement.images.original.size, | ||||||
|                 "mimetype": "image/gif", |                 "mimetype": "image/webp", | ||||||
|                 "thumbnail_info": { |  | ||||||
|                     "h": jsonElement.images.fixed_width_still.height, |  | ||||||
|                     "mimetype": "image/jpg", |  | ||||||
|                     "size": jsonElement.images.fixed_width_still.size, |  | ||||||
|                     "w": jsonElement.images.fixed_width_still.width |  | ||||||
|                 }, |  | ||||||
|                 "thumbnail_url": jsonElement.images.fixed_width_still.url |  | ||||||
|             }, |             }, | ||||||
|            "msgtype": "m.image", |            "msgtype": "m.image", | ||||||
|            "url": jsonElement.images.original.url |            "url": mxc_prefix+jsonElement.id | ||||||
|         }; |         }; | ||||||
|         this.setState((prevState) => ({  |         this.setState((prevState) => ({  | ||||||
|             GIFById: {...prevState.GIFById, [id]: updatedItem}})); |             GIFById: {...prevState.GIFById, [id]: updatedItem}})); | ||||||
| @ -265,6 +259,7 @@ class App extends Component { | |||||||
| 			const indexData = await indexRes.json() | 			const indexData = await indexRes.json() | ||||||
| 			HOMESERVER_URL = indexData.homeserver_url || HOMESERVER_URL | 			HOMESERVER_URL = indexData.homeserver_url || HOMESERVER_URL | ||||||
|             GIPHY_API_KEY = indexData.giphy_api_key || "" |             GIPHY_API_KEY = indexData.giphy_api_key || "" | ||||||
|  |             GIPHY_MXC_PREFIX = indexData.giphy_mxc_prefix || GIPHY_MXC_PREFIX | ||||||
| 			// TODO only load pack metadata when scrolled into view?
 | 			// TODO only load pack metadata when scrolled into view?
 | ||||||
| 			for (const packFile of indexData.packs) { | 			for (const packFile of indexData.packs) { | ||||||
| 				let packRes | 				let packRes | ||||||
|  | |||||||
| @ -13,178 +13,68 @@ | |||||||
| //
 | //
 | ||||||
| // You should have received a copy of the GNU Affero General Public License
 | // You should have received a copy of the GNU Affero General Public License
 | ||||||
| // along with this program.  If not, see <https://www.gnu.org/licenses/>.
 | // along with this program.  If not, see <https://www.gnu.org/licenses/>.
 | ||||||
|  | let widgetId = null | ||||||
| 
 | 
 | ||||||
| const urlParams = new URLSearchParams(window.location.search); | window.onmessage = event => { | ||||||
| const widgetId = urlParams.get('widgetId'); // if you know the widget ID, supply it.
 | 	if (!window.parent || !event.data) { | ||||||
| console.log("Widget ID:"+widgetId); | 		return | ||||||
| const api = new mxwidgets.WidgetApi(widgetId, '*'); | 	} | ||||||
| 
 | 
 | ||||||
|  | 	const request = event.data | ||||||
|  | 	if (!request.requestId || !request.widgetId || !request.action || request.api !== "toWidget") { | ||||||
|  | 		return | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| // Before doing anything else, request capabilities:
 | 	if (widgetId) { | ||||||
| api.requestCapabilities(mxwidgets.StickerpickerCapabilities); | 		if (widgetId !== request.widgetId) { | ||||||
| api.requestCapability(mxwidgets.MatrixCapabilities.MSC4039UploadFile); | 			return | ||||||
|  | 		} | ||||||
|  | 	} else { | ||||||
|  | 		widgetId = request.widgetId | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| api.on("ready", () => {console.log("ready event received")}); | 	let response | ||||||
| 
 | 
 | ||||||
| // Start the messaging
 | 	if (request.action === "visibility") { | ||||||
| api.start(); | 		response = {} | ||||||
|  | 	} else if (request.action === "capabilities") { | ||||||
|  | 		response = { capabilities: ["m.sticker"] } | ||||||
|  | 	} else { | ||||||
|  | 		response = { error: { message: "Action not supported" } } | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| // If waitForIframeLoad is false, tell the client that we're good to go
 | 	window.parent.postMessage({ ...request, response }, event.origin) | ||||||
| //api.sendContentLoaded();
 | } | ||||||
| 
 | 
 | ||||||
| export function sendSticker(content){ | export function sendSticker(content) { | ||||||
| 	const data = { | 	const data = { | ||||||
|         content: {...content}, | 		content: { ...content }, | ||||||
|  | 		// `name` is for Element Web (and also the spec)
 | ||||||
|  | 		// Element Android uses content -> body as the name
 | ||||||
| 		name: content.body, | 		name: content.body, | ||||||
|     }; | 	} | ||||||
|     // do the same thing that tulir does
 | 	// Custom field that stores the ID even for non-telegram stickers
 | ||||||
|     delete data.content.id; | 	delete data.content.id | ||||||
|     // send data
 | 
 | ||||||
|     api.sendSticker(data); | 	// This is for Element iOS
 | ||||||
|  | 	const widgetData = { | ||||||
|  | 		...data, | ||||||
|  | 		description: content.body, | ||||||
|  | 		file: `${content.id}.png`, | ||||||
|  | 	} | ||||||
|  | 	// Element iOS explodes if there are extra fields present
 | ||||||
|  | 	delete widgetData.content["net.maunium.telegram.sticker"] | ||||||
|  | 
 | ||||||
|  | 	window.parent.postMessage({ | ||||||
|  | 		api: "fromWidget", | ||||||
|  | 		action: "m.sticker", | ||||||
|  | 		requestId: `sticker-${Date.now()}`, | ||||||
|  | 		widgetId, | ||||||
|  | 		data, | ||||||
|  | 		widgetData, | ||||||
|  | 	}, "*") | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /* | export function sendGIF(content) { | ||||||
|  *export function sendGIF(content){ |     return sendSticker(content) | ||||||
|  *    // just print out content, should be URL
 |  | ||||||
|  *    console.log("Content:"+content.url); |  | ||||||
|  *    return new Promise((resolve, reject) => { |  | ||||||
|  *    const xhr = new XMLHttpRequest(); |  | ||||||
|  *    xhr.open('GET', content.url, true); |  | ||||||
|  *    xhr.onreadystatechange = function() { |  | ||||||
|  *      if (xhr.readyState === 4) { |  | ||||||
|  *        if (xhr.status === 200) { |  | ||||||
|  *          const responseData = xhr.responseText; |  | ||||||
|  *          // Call uploadFile with response data
 |  | ||||||
|  *          api.uploadFile(responseData) |  | ||||||
|  *            .then(result => { |  | ||||||
|  *                console.log("Here's the result:"+result.content_uri); |  | ||||||
|  *                // mess around with the content object, then send it as sticker
 |  | ||||||
|  *                content.url = result.content_uri; |  | ||||||
|  *                sendSticker(content); |  | ||||||
|  *              resolve(result); |  | ||||||
|  *            }) |  | ||||||
|  *            .catch(error => { |  | ||||||
|  *              reject(error); |  | ||||||
|  *            }); |  | ||||||
|  *        } else { |  | ||||||
|  *          reject(new Error('Failed to fetch data')); // Reject the outer promise if fetching data fails
 |  | ||||||
|  *        } |  | ||||||
|  *      } |  | ||||||
|  *    }; |  | ||||||
|  *    xhr.send(); |  | ||||||
|  *  });  |  | ||||||
|  *} |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| export async function sendGIF(content){ |  | ||||||
|     // just print content, since it's a custom type with URL
 |  | ||||||
|     console.log("Content:"+content.url); |  | ||||||
|     // use fetch because I'm on IE
 |  | ||||||
|     const lol = await fetch(content.url); |  | ||||||
|     const uri_file = await lol.blob(); |  | ||||||
|     // call uploadFile with this
 |  | ||||||
|     var result = await api.uploadFile(uri_file) |  | ||||||
|     console.log("Got URI:"+result.content_uri); |  | ||||||
|     content.url = result.content_uri; |  | ||||||
|     // get thumbnail
 |  | ||||||
|     //const thumb_uri = await fetch(content.info.thumbnail_url)
 |  | ||||||
|     //const thumb_file = await thumb_uri.blob();
 |  | ||||||
|     //result = await api.uploadFile(thumb_file)
 |  | ||||||
|     //console.log("Thumb URI:"+result.content_uri);
 |  | ||||||
|     //content.info.thumbnail_url = result.content_uri;
 |  | ||||||
|     // actually, just delete the thumbnail
 |  | ||||||
|     delete content.info.thumbnail_url; |  | ||||||
|     // finally, send it as sticker
 |  | ||||||
|     sendSticker(content); |  | ||||||
| 
 |  | ||||||
| } | } | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| /* |  | ||||||
|  *let widgetId = null |  | ||||||
|  * |  | ||||||
|  *window.onmessage = event => { |  | ||||||
|  *    if (!window.parent || !event.data) { |  | ||||||
|  *        return |  | ||||||
|  *    } |  | ||||||
|  * |  | ||||||
|  *    const request = event.data |  | ||||||
|  *    if (!request.requestId || !request.widgetId || !request.action || request.api !== "toWidget") { |  | ||||||
|  *        return |  | ||||||
|  *    } |  | ||||||
|  * |  | ||||||
|  *    if (widgetId) { |  | ||||||
|  *        if (widgetId !== request.widgetId) { |  | ||||||
|  *            return |  | ||||||
|  *        } |  | ||||||
|  *    } else { |  | ||||||
|  *        widgetId = request.widgetId |  | ||||||
|  *    } |  | ||||||
|  * |  | ||||||
|  *    let response |  | ||||||
|  * |  | ||||||
|  *    if (request.action === "visibility") { |  | ||||||
|  *        response = {} |  | ||||||
|  *    } else if (request.action === "capabilities") { |  | ||||||
|  *        response = { capabilities: ["m.sticker", "org.matrix.msc4039.upload_file"] } |  | ||||||
|  *    } else { |  | ||||||
|  *        response = { error: { message: "Action not supported" } } |  | ||||||
|  *    } |  | ||||||
|  * |  | ||||||
|  *    window.parent.postMessage({ ...request, response }, event.origin) |  | ||||||
|  *} |  | ||||||
|  * |  | ||||||
|  *export function sendSticker(content) { |  | ||||||
|  *    const data = { |  | ||||||
|  *        content: { ...content }, |  | ||||||
|  *        // `name` is for Element Web (and also the spec)
 |  | ||||||
|  *        // Element Android uses content -> body as the name
 |  | ||||||
|  *        name: content.body, |  | ||||||
|  *    } |  | ||||||
|  *    // Custom field that stores the ID even for non-telegram stickers
 |  | ||||||
|  *    delete data.content.id |  | ||||||
|  * |  | ||||||
|  *    // This is for Element iOS
 |  | ||||||
|  *    const widgetData = { |  | ||||||
|  *        ...data, |  | ||||||
|  *        description: content.body, |  | ||||||
|  *        file: `${content.id}.png`, |  | ||||||
|  *    } |  | ||||||
|  *    // Element iOS explodes if there are extra fields present
 |  | ||||||
|  *    delete widgetData.content["net.maunium.telegram.sticker"] |  | ||||||
|  * |  | ||||||
|  *    window.parent.postMessage({ |  | ||||||
|  *        api: "fromWidget", |  | ||||||
|  *        action: "m.sticker", |  | ||||||
|  *        requestId: `sticker-${Date.now()}`, |  | ||||||
|  *        widgetId, |  | ||||||
|  *        data, |  | ||||||
|  *        widgetData, |  | ||||||
|  *    }, "*") |  | ||||||
|  *} |  | ||||||
|  * |  | ||||||
|  *export function sendGIF(content) { |  | ||||||
|  *    const data = { |  | ||||||
|  *        content: { ...content }, |  | ||||||
|  *        name: content.body, |  | ||||||
|  *        msgtype: "m.image" |  | ||||||
|  *    } |  | ||||||
|  * |  | ||||||
|  *    delete data.content.id |  | ||||||
|  *    // This is for Element iOS
 |  | ||||||
|  *    const widgetData = { |  | ||||||
|  *        ...data, |  | ||||||
|  *        description: content.body, |  | ||||||
|  *        file: `${content.id}.png`, |  | ||||||
|  *    } |  | ||||||
|  * |  | ||||||
|  *    window.parent.postMessage({ |  | ||||||
|  *        api: "fromWidget", |  | ||||||
|  *        action: "m.room.message", |  | ||||||
|  *        requestId: `gif-${Date.now()}`, |  | ||||||
|  *        widgetId, |  | ||||||
|  *        data, |  | ||||||
|  *        widgetData, |  | ||||||
|  *    }, "*") |  | ||||||
|  *} |  | ||||||
|  */ |  | ||||||
|  | |||||||
| @ -1,16 +1 @@ | |||||||
| *{font-family:sans-serif}body{margin:0}h1{font-size:1rem}:root{--stickers-per-row: 4;--sticker-size: calc(100vw / var(--stickers-per-row))}main{color:var(--text-color)}main.spinner{margin-top:5rem}main.error,main.empty{margin:2rem}main.empty{text-align:center}main.has-content{position:fixed;top:0;left:0;right:0;bottom:0;display:grid;grid-template-rows:calc(12vw + 2px) min-content auto}main.theme-light{--highlight-color: #eee;--search-box-color: var(--highlight-color);--text-color: black;background-color:#fff}main.theme-dark{--highlight-color: #444;--search-box-color: #383e4b;--text-color: white;background-color:#22262e}main.theme-black{--highlight-color: #222;--search-box-color: var(--highlight-color);--text-color: white;background-color:#000}.icon{width:100%;height:100%;background-color:var(--text-color);mask-size:contain;-webkit-mask-size:contain;mask-image:var(--icon-image);-webkit-mask-image:var(--icon-image)}.icon.icon-settings{--icon-image: url(../res/settings.svg)}.icon.icon-recent{--icon-image: url(../res/recent.svg)}.icon.icon.icon-search{--icon-image: url(../res/search.svg)}nav{display:flex;overflow-x:auto}nav>a{border-bottom:2px solid transparent}nav>a.visible{border-bottom-color:green}nav>a>div.sticker{width:12vw;height:12vw}div.pack-list,nav{scrollbar-width:none}div.pack-list::-webkit-scrollbar,nav::-webkit-scrollbar{display:none}div.pack-list{overflow-y:auto}div.pack-list.ios-safari-hack{position:fixed;top:calc(calc(12vw + 2px) + calc(2 * 0.7rem + 2 * 0.5rem + 1rem));bottom:0;left:0;right:0;-webkit-overflow-scrolling:touch}div.search-empty{margin:1.2rem;text-align:center}section.stickerpack{margin-top:.75rem}section.stickerpack>div.sticker-list{display:flex;flex-wrap:wrap}section.stickerpack>h1{margin:0 0 0 .75rem}div.sticker{display:flex;padding:4px;cursor:pointer;position:relative;width:var(--sticker-size);height:var(--sticker-size);box-sizing:border-box}div.sticker:hover{background-color:var(--highlight-color)}div.sticker>img{display:none;width:100%;object-fit:contain}div.sticker>img.visible{display:initial}div.sticker>.icon{width:70%;height:70%;margin:15%}div.search-box{position:relative;display:flex}div.search-box>input[type=text]{flex-grow:1;background-color:var(--search-box-color);outline:none;border:none;border-radius:.25rem;height:1rem;padding:.7rem;padding-right:calc(1rem + 0.7rem);margin:.5rem;font-size:1rem;color:var(--text-color)}div.search-box>span.icon{display:flex;position:absolute;top:calc(50% - 1rem / 2);right:1rem;width:1rem;height:1rem;box-sizing:border-box}div.settings-list{display:flex;flex-direction:column}div.settings-list>*{margin:.5rem}div.settings-list button{padding:.5rem;border-radius:.25rem}div.settings-list input{width:100%} | *{font-family:sans-serif}body{margin:0}h1{font-size:1rem}:root{--stickers-per-row: 4;--sticker-size: calc(100vw / var(--stickers-per-row))}main{color:var(--text-color)}main.spinner{margin-top:5rem}main.error,main.empty{margin:2rem}main.empty{text-align:center}main.has-content{position:fixed;top:0;left:0;right:0;bottom:0;display:grid;grid-template-rows:calc(12vw + 2px) min-content auto}main.theme-light{--highlight-color: #eee;--search-box-color: var(--highlight-color);--text-color: black;background-color:#fff}main.theme-dark{--highlight-color: #444;--search-box-color: #383e4b;--text-color: white;background-color:#22262e}main.theme-black{--highlight-color: #222;--search-box-color: var(--highlight-color);--text-color: white;background-color:#000}.icon{width:100%;height:100%;background-color:var(--text-color);mask-size:contain;-webkit-mask-size:contain;mask-image:var(--icon-image);-webkit-mask-image:var(--icon-image)}.icon.icon-settings{--icon-image: url(../res/settings.svg)}.icon.icon-recent{--icon-image: url(../res/recent.svg)}.icon.icon.icon-search{--icon-image: url(../res/search.svg)}nav{display:flex;overflow-x:auto}nav>a{border-bottom:2px solid rgba(0,0,0,0)}nav>a.visible{border-bottom-color:green}nav>a>div.sticker{width:12vw;height:12vw}div.pack-list,nav{scrollbar-width:none}div.pack-list::-webkit-scrollbar,nav::-webkit-scrollbar{display:none}div.pack-list{overflow-y:auto}div.pack-list.ios-safari-hack{position:fixed;top:calc(calc(12vw + 2px) + calc(2 * 0.7rem + 2 * 0.5rem + 1rem));bottom:0;left:0;right:0;-webkit-overflow-scrolling:touch}div.search-empty{margin:1.2rem;text-align:center}section.stickerpack{margin-top:.75rem}section.stickerpack>div.sticker-list{display:flex;flex-wrap:wrap}section.stickerpack>h1{margin:0 0 0 .75rem}div.sticker{display:flex;padding:4px;cursor:pointer;position:relative;width:var(--sticker-size);height:var(--sticker-size);box-sizing:border-box}div.sticker:hover{background-color:var(--highlight-color)}div.sticker>img{display:none;width:100%;object-fit:contain}div.sticker>img.visible{display:initial}div.sticker>.icon{width:70%;height:70%;margin:15%}div.search-box{position:relative;display:flex}div.search-box>input[type=text]{flex-grow:1;background-color:var(--search-box-color);outline:none;border:none;border-radius:.25rem;height:1rem;padding:.7rem;padding-right:calc(1rem + 0.7rem);margin:.5rem;font-size:1rem;color:var(--text-color)}div.search-box>span.icon{display:flex;position:absolute;top:calc(50% - 1rem/2);right:1rem;width:1rem;height:1rem;box-sizing:border-box}div.settings-list{display:flex;flex-direction:column}div.settings-list>*{margin:.5rem}div.settings-list button{padding:.5rem;border-radius:.25rem}div.settings-list input{width:100%}a.tab{padding:5% 5%;width:40%;text-align:center;border:none;background-color:#f0f0f0;cursor:pointer;-webkit-appearance:button;-moz-appearance:button;appearance:button;text-decoration:none;color:initial} | ||||||
| 
 |  | ||||||
| a.tab { |  | ||||||
|   padding: 5% 5%; |  | ||||||
|   width: 40%; |  | ||||||
|   text-align: center; |  | ||||||
|   border: none; |  | ||||||
|   background-color: #f0f0f0; |  | ||||||
|   cursor: pointer; |  | ||||||
|     -webkit-appearance: button; |  | ||||||
|     -moz-appearance: button; |  | ||||||
|     appearance: button; |  | ||||||
| 
 |  | ||||||
|     text-decoration: none; |  | ||||||
|     color: initial; |  | ||||||
|   } |  | ||||||
|  | |||||||
| @ -204,4 +204,16 @@ div.settings-list | |||||||
| 
 | 
 | ||||||
|   input |   input | ||||||
|     width: 100% |     width: 100% | ||||||
|  | a.tab | ||||||
|  |   padding: 5% 5% | ||||||
|  |   width: 40% | ||||||
|  |   text-align: center | ||||||
|  |   border: none | ||||||
|  |   background-color: #f0f0f0 | ||||||
|  |   cursor: pointer | ||||||
|  |   -webkit-appearance: button | ||||||
|  |   -moz-appearance: button | ||||||
|  |   appearance: button | ||||||
| 
 | 
 | ||||||
|  |   text-decoration: none | ||||||
|  |   color: initial | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user