FEATURE: Add fullscreen-tables to post (#14709)

Overflown tables will have a "expand table" option added to open x table in a modal
This commit is contained in:
janzenisaac 2021-10-25 14:06:28 -05:00 committed by GitHub
parent 116982fca9
commit dd5b0543c7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 123 additions and 2 deletions

View File

@ -1,11 +1,13 @@
import { later } from "@ember/runloop"; import { later, schedule } from "@ember/runloop";
import I18n from "I18n"; import I18n from "I18n";
import highlightSyntax from "discourse/lib/highlight-syntax"; import highlightSyntax from "discourse/lib/highlight-syntax";
import lightbox from "discourse/lib/lightbox"; import lightbox from "discourse/lib/lightbox";
import { iconHTML } from "discourse-common/lib/icon-library"; import { iconHTML, iconNode } from "discourse-common/lib/icon-library";
import { setTextDirections } from "discourse/lib/text-direction"; import { setTextDirections } from "discourse/lib/text-direction";
import { nativeLazyLoading } from "discourse/lib/lazy-load-images"; import { nativeLazyLoading } from "discourse/lib/lazy-load-images";
import { withPluginApi } from "discourse/lib/plugin-api"; import { withPluginApi } from "discourse/lib/plugin-api";
import { create } from "virtual-dom";
import showModal from "discourse/lib/show-modal";
export default { export default {
name: "post-decorations", name: "post-decorations",
@ -131,6 +133,61 @@ export default {
}, },
{ id: "discourse-video-codecs" } { id: "discourse-video-codecs" }
); );
function _createButton() {
const openPopupBtn = document.createElement("button");
openPopupBtn.classList.add(
"open-popup-link",
"btn-default",
"btn",
"btn-icon-text"
);
const expandIcon = create(
iconNode("discourse-expand", { class: "expand-table-icon" })
);
const openPopupText = document.createTextNode(
I18n.t("fullscreen_table.expand_btn")
);
openPopupBtn.append(expandIcon, openPopupText);
return openPopupBtn;
}
function isOverflown({ clientWidth, scrollWidth }) {
return scrollWidth > clientWidth;
}
function generateModal(event) {
const table = event.target.parentNode.querySelector("table");
const tempTable = table.cloneNode(true);
showModal("fullscreen-table").set("tableHtml", tempTable);
}
function generatePopups(tables) {
tables.forEach((table) => {
if (!isOverflown(table.parentNode)) {
return;
}
const popupBtn = _createButton();
table.parentNode.classList.add("fullscreen-table-wrapper");
table.parentNode.insertBefore(popupBtn, table);
popupBtn.addEventListener("click", generateModal, false);
});
}
api.decorateCookedElement(
(post) => {
schedule("afterRender", () => {
const tables = post.querySelectorAll("table");
generatePopups(tables);
});
},
{
onlyStream: true,
id: "fullscreen-table",
}
);
}); });
}, },
}; };

View File

@ -0,0 +1,3 @@
{{#d-modal-body}}
{{tableHtml}}
{{/d-modal-body}}

View File

@ -1410,3 +1410,56 @@ a.mention-group {
opacity: 0; opacity: 0;
} }
} }
.open-popup-link {
position: sticky;
left: 0.5rem;
top: 0.5rem;
opacity: 0%;
white-space: nowrap;
display: block;
}
.fullscreen-table-wrapper {
transition: all 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
display: block;
}
.expand-table-icon {
margin-right: 4px;
}
.fullscreen-table-modal .modal-inner-container {
width: max-content;
max-width: 90%;
margin: 0 auto;
padding: 10px;
.modal-body {
padding-top: 0;
}
thead {
position: sticky;
top: 0;
z-index: 1;
background-color: var(--secondary);
}
tbody {
overflow-x: hidden;
}
td {
padding: 0.5rem;
}
}
html.discourse-no-touch .fullscreen-table-wrapper:hover {
border-radius: 5px;
box-shadow: 0 2px 5px 0 rgba(var(--always-black-rgb), 0.1),
0 2px 10px 0 rgba(var(--always-black-rgb), 0.1);
.open-popup-link {
opacity: 100%;
}
}

View File

@ -458,3 +458,8 @@ span.highlighted {
} }
} }
} }
.open-popup-link {
opacity: 100%;
margin-bottom: 1rem;
}

View File

@ -3938,6 +3938,9 @@ en:
no_group_messages_title: "No group messages found" no_group_messages_title: "No group messages found"
fullscreen_table:
expand_btn: "Expand Table"
# This section is exported to the javascript for i18n in the admin section # This section is exported to the javascript for i18n in the admin section
admin_js: admin_js:
type_to_filter: "type to filter..." type_to_filter: "type to filter..."