mirror of
https://github.com/MichMich/MagicMirror.git
synced 2026-04-25 23:32:10 +00:00
I was playing around with the newsfeed notification system (`ARTICLE_MORE_DETAILS`, `ARTICLE_TOGGLE_FULL`, …) and discovered some issues with the full article view: The iframe was loading the CORS proxy URL instead of the actual article URL, which could cause blank screens depending on the feed. Also, many news sites block iframes entirely (`X-Frame-Options: DENY`) and the user got no feedback at all — just an empty page. On top of that, scrolling used `window.scrollTo()` which moved the entire MagicMirror page instead of just the article. This PR cleans that up: - Use the raw article URL for the iframe (CORS proxy is only needed for server-side feed fetching) - Check `X-Frame-Options` / `Content-Security-Policy` headers server-side before showing the iframe — if the site blocks it, show a brief "Article cannot be displayed here." message and return to normal view - Show the iframe as a fixed full-screen overlay so other modules aren't affected, scroll via `container.scrollTop` - Keep the progressive disclosure behavior for `ARTICLE_MORE_DETAILS` (title → description → iframe → scroll) - Delete `fullarticle.njk`, replace with `getDom()` override - Fix `ARTICLE_INFO_RESPONSE` returning proxy URL instead of real URL - A few smaller fixes (negative scroll, null guard) - Add `NEWSFEED_ARTICLE_UNAVAILABLE` translation to all 47 language files - Add e2e tests for the notification handlers (`ARTICLE_NEXT`, `ARTICLE_PREVIOUS`, `ARTICLE_INFO_REQUEST`, `ARTICLE_LESS_DETAILS`) ## What this means for users - The full article view now works reliably across different feeds - If a news site blocks iframes, the user sees a brief message instead of a blank screen - Additional e2e tests make the module more robust and less likely to break silently in future MagicMirror versions
55 lines
1.7 KiB
JSON
55 lines
1.7 KiB
JSON
{
|
|
"LOADING": "loS …",
|
|
|
|
"DAYBEFOREYESTERDAY": "cha'Hu'",
|
|
"YESTERDAY": "wa'Hu'",
|
|
"TODAY": "DaHjaj",
|
|
"TOMORROW": "wa'leS",
|
|
"DAYAFTERTOMORROW": "cha'leS",
|
|
"RUNNING": "Dor",
|
|
"EMPTY": "Sumbe' wanI'.",
|
|
"WEEK": "Hogh (terran) {weekNumber}",
|
|
|
|
"N": "N",
|
|
"NNE": "NNE",
|
|
"NE": "NE",
|
|
"ENE": "ENE",
|
|
"E": "chan",
|
|
"ESE": "ESE",
|
|
"SE": "SE",
|
|
"SSE": "SSE",
|
|
"S": "S",
|
|
"SSW": "SSW",
|
|
"SW": "tIng",
|
|
"WSW": "WSW",
|
|
"W": "W",
|
|
"WNW": "WNW",
|
|
"NW": "'ev",
|
|
"NNW": "NNW",
|
|
|
|
"FEELS": "jem {DEGREE}",
|
|
"PRECIP_POP": "nIHmey",
|
|
"PRECIP_AMOUNT": "nIHmey Daq",
|
|
|
|
"MODULE_CONFIG_CHANGED": "mIghtaH {MODULE_NAME} mIghtaHmey lIjwI'pu'.\nDoHbe' yImev.",
|
|
"MODULE_CONFIG_ERROR": "{MODULE_NAME} mIghtaHmeyDaq ghobe' yImev. {ERROR}",
|
|
"MODULE_ERROR_MALFORMED_URL": "URL ghobe' yImev.",
|
|
"MODULE_ERROR_NO_CONNECTION": "Internet ghobe' yImev.",
|
|
"MODULE_ERROR_UNAUTHORIZED": "ghobe' yImev.",
|
|
"MODULE_ERROR_RATE_LIMITED": "tlhoy rurqu' lut. vaj ratlh.",
|
|
"MODULE_ERROR_SERVER_ERROR": "Qagh server. vaj ratlh.",
|
|
"MODULE_ERROR_CLIENT_ERROR": "lut Qagh.",
|
|
"MODULE_ERROR_UNSPECIFIED": "logmeyDaq yImev.",
|
|
|
|
"NEWSFEED_NO_ITEMS": "DaHghachmey ghobe' yImev.",
|
|
"NEWSFEED_ARTICLE_UNAVAILABLE": "QIngheb cha' tu'be'lu'.",
|
|
|
|
"UPDATE_NOTIFICATION": " De'chu' MagicMirror² lI'laH.",
|
|
"UPDATE_NOTIFICATION_MODULE": "bobcho' {MODULE_NAME} lI'laH De'chu.",
|
|
"UPDATE_INFO_SINGLE": "{BRANCH_NAME} ghoghDaq {COMMIT_COUNT} commit lIjwI'pu'.",
|
|
"UPDATE_INFO_MULTIPLE": "{BRANCH_NAME} ghoghDaq {COMMIT_COUNT} commit lIjwI'pu'.",
|
|
"UPDATE_NOTIFICATION_DONE": "{MODULE_NAME} mIghtaHmeyDaq bobcho' lIjwI'pu'.",
|
|
"UPDATE_NOTIFICATION_ERROR": "{MODULE_NAME} mIghtaHmeyDaq bobcho' ghobe' yImev.",
|
|
"UPDATE_NOTIFICATION_NEED-RESTART": "MagicMirrorDaq yImev."
|
|
}
|