Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature/sc 27385/publish settings2 #2180

Draft
wants to merge 47 commits into
base: feature/sc-30094/add-sheet-options-to-sheets-editor
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
47 commits
Select commit Hold shift + click to select a range
eb94e21
chore: publish button
stevekaplan123 Nov 11, 2024
8e7372e
chore: start implementing publish button
stevekaplan123 Nov 11, 2024
db55ead
Merge branch 'feature/sc-30094/add-sheet-options-to-sheets-editor' in…
stevekaplan123 Nov 11, 2024
c589db1
chore: publish button and unpublish button when appropriate
stevekaplan123 Nov 11, 2024
c68f85a
chore: publish button css
stevekaplan123 Nov 11, 2024
7787587
chore: start PublishModal
stevekaplan123 Nov 12, 2024
c677afd
Merge branch 'feature/sc-30094/add-sheet-options-to-sheets-editor' in…
stevekaplan123 Nov 12, 2024
a7a1772
chore: togglePublish not working due to lastModified dateModified issue
stevekaplan123 Nov 12, 2024
a0a5b0d
chore: lastModified passed to SheetOptions, dont pass SheetOptions do…
stevekaplan123 Nov 13, 2024
f7894d2
chore: publish button does not open modal but does publish
stevekaplan123 Nov 13, 2024
d42812b
chore: sheetIsPublished doesnt need to be state
stevekaplan123 Nov 13, 2024
7140f96
chore: start publishmodal
stevekaplan123 Nov 14, 2024
36a9e71
chore: use ReactTags in PublishModal
stevekaplan123 Nov 14, 2024
8e33419
chore: use textarea for summary
stevekaplan123 Nov 14, 2024
02d1ad1
chore: dont need to pass sheet
stevekaplan123 Nov 17, 2024
2afcf74
chore: add validation from aboutsheet
stevekaplan123 Nov 19, 2024
51a719f
chore: start css styling of publish box
stevekaplan123 Nov 19, 2024
0bf5ab1
chore: PublishModal contains PublishMenu
stevekaplan123 Nov 20, 2024
252c8d8
fix: published sheets once modified do not get unpublished
stevekaplan123 Nov 20, 2024
d9bfb3c
chore: set publish status on sefaria editor level
stevekaplan123 Nov 20, 2024
6fd6f0f
chore: title and summary implemented using react state
stevekaplan123 Nov 21, 2024
5764fd3
chore: title and summary update but sheet gets saved twice upon initi…
stevekaplan123 Nov 21, 2024
15c8508
Merge branch 'feature/sc-30094/add-sheet-options-to-sheets-editor' in…
stevekaplan123 Nov 24, 2024
8f348be
chore: use Untitled placeholder
stevekaplan123 Nov 24, 2024
4ab45e9
chore: default to Untitled in post
stevekaplan123 Nov 24, 2024
b664125
chore: postSheet should be synchronous
stevekaplan123 Nov 26, 2024
1457050
chore: lastModified doesnt need to be state. it can be derived from …
stevekaplan123 Nov 27, 2024
833bd32
Merge branch 'feature/sc-30094/add-sheet-options-to-sheets-editor' in…
stevekaplan123 Nov 28, 2024
9cab141
Merge branch 'feature/sc-30094/add-sheet-options-to-sheets-editor' in…
stevekaplan123 Dec 1, 2024
923eeb9
chore: shared -> common directory
stevekaplan123 Dec 1, 2024
d307f74
chore: css adjustments for publish modal
stevekaplan123 Dec 1, 2024
0acedb6
chore: catch error in calling postSheet
stevekaplan123 Dec 2, 2024
ae2dc58
Merge branch 'feature/sc-30094/add-sheet-options-to-sheets-editor' in…
stevekaplan123 Dec 11, 2024
368aba4
Merge branch 'feature/sc-30094/add-sheet-options-to-sheets-editor' in…
stevekaplan123 Dec 15, 2024
57ae1dc
chore: pass handleCollectionsChange from Sheet to Editor to SheetOptions
stevekaplan123 Dec 15, 2024
9512706
chore: css fix
stevekaplan123 Dec 15, 2024
14f58a9
Merge branch 'feature/sc-30094/add-sheet-options-to-sheets-editor' in…
stevekaplan123 Dec 17, 2024
88e543f
chore: add comment
stevekaplan123 Dec 19, 2024
8c73eb8
chore: clarify comment
stevekaplan123 Dec 22, 2024
b694300
Merge branch 'feature/sc-30093/title-summary-editable-in-sheets-edito…
stevekaplan123 Dec 23, 2024
5cb57dc
Merge branch 'feature/sc-30094/add-sheet-options-to-sheets-editor' in…
stevekaplan123 Dec 23, 2024
64a2763
Merge branch 'feature/sc-30094/add-sheet-options-to-sheets-editor' in…
stevekaplan123 Dec 24, 2024
d36513b
Merge branch 'feature/sc-30094/add-sheet-options-to-sheets-editor' in…
stevekaplan123 Dec 24, 2024
feae111
chore: menuIcon to button
stevekaplan123 Dec 30, 2024
8ce15aa
Merge branch 'feature/sc-30094/add-sheet-options-to-sheets-editor' in…
stevekaplan123 Jan 12, 2025
ccb70d0
Merge branch 'feature/sc-30094/add-sheet-options-to-sheets-editor' in…
stevekaplan123 Jan 16, 2025
2f8319c
Merge branch 'feature/sc-30094/add-sheet-options-to-sheets-editor' in…
stevekaplan123 Jan 16, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
81 changes: 57 additions & 24 deletions static/css/s2.css
Original file line number Diff line number Diff line change
Expand Up @@ -8137,7 +8137,14 @@ a .button:hover {
width: -moz-fit-content;
width: fit-content;
}

.button.small.publish {
color: #666666;
background-color: white;
font-weight: 500;
min-height: 31px;
height: 31px;
padding: 0 10px;
}
.headerWithAdminButtonsContainer{
display: flex;
justify-content: space-between;
Expand Down Expand Up @@ -8581,6 +8588,7 @@ a.sheetAuthorName:hover {
flex: 1 0 95%;
text-align: initial;
}

.sheetMetaDataBox .title:empty:before {
content: "Untitled";
color: #999;
Expand All @@ -8600,14 +8608,25 @@ a.sheetAuthorName:hover {
}
.publishBox {
text-align: start;
background-color: #EDEDEC;
border-radius: 6px;
padding: 10px 20px;
max-width: 540px;
width: 500px;
margin: 20px -20px;
font-size: 16px;
color: #666;
}
.publishBox .publishLabel {
--english-font: var(--english-sans-serif-font-family);
--hebrew-font: var(--hebrew-sans-serif-font-family);
font-size: 14px;
font-weight: 400;
line-height: 18px;
text-underline-position: from-font;
text-decoration-skip-ink: none;
color: var(--dark-grey);
margin-bottom: 10px;
}

div.transparentBackground.publishBox {
background-color: inherit;
Expand All @@ -8629,6 +8648,38 @@ div.transparentBackground.publishBox {
.publishBox textarea.error {
border: 1px solid red;
}
.sheetMetaDataBox .publishBox .react-tags__selected {
display: inline;
}
.sheetMetaDataBox .publishBox .react-tags__selected-tag {
display: inline-block;
box-sizing: border-box;
margin: 0 6px 6px 0;
padding: 6px 8px;
border: none;
border-radius: 6px;
background: #FFFFFF;
color: #000;
/* match the font styles */
font-family: inherit;
font-size: inherit;
line-height: inherit;
}
.sheetMetaDataBox .publishBox textarea, .sheetMetaDataBox .publishBox input, .sheetMetaDataBox .publishBox .react-tags {
border-radius: 6px;
border: none;
width: 98%;
padding: 7px;
background: #EDEDEC;
--english-font: var(--english-sans-serif-font-family);
--hebrew-font: var(--hebrew-sans-serif-font-family);
font-size: 16px;
font-weight: 400;
line-height: 18.75px;
text-underline-position: from-font;
text-decoration-skip-ink: none;
margin-bottom: 10px;
}
.publishBox p strong {
color: black;
font-weight: 400;
Expand All @@ -8652,26 +8703,6 @@ div.transparentBackground.publishBox {
.publishBox .smallText {
color: #666666
}
.publishBox textarea {
width: 100%;
height: 100px;
resize: none;
box-sizing: border-box;
font-size: 16px;
color: #000;
border: none;
border-radius: 6px;
box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.25);
font-style: normal;
padding: 10px 10px 4px 10px;
margin-bottom: 0px;
}
.publishBox textarea::placeholder {
font-size: 16px;
color: #666;
font-style: normal;
font-family: var(--english-sans-serif-font-family);
}
.publishBox .react-tags {
position: relative;
padding: 10px 10px 4px 10px;
Expand Down Expand Up @@ -10564,6 +10595,8 @@ span.purim-emoji img{
}
.sheetContent .spacer:only-of-type.empty {
line-height: inherit;
--english-font: var(--english-sans-serif-font-family);
--hebrew-font: var(--hebrew-sans-serif-font-family);
}
.sheetItem:only-of-type.empty .SheetOutsideText:before,
.sheetContent .spacer:only-of-type.empty:before {
Expand Down Expand Up @@ -14160,8 +14193,8 @@ span.ref-link-color-3 {color: blue}
}
.sheetsInPanel .headerDropdownMenu {
min-width: 50%;
margin-top: 10px;
color: #666;
margin-top: 7px;
color: var(--dark-grey);
cursor: pointer;
position: relative;
-webkit-margin-start: 20px;
Expand Down
3 changes: 3 additions & 0 deletions static/icons/unpublish.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
81 changes: 45 additions & 36 deletions static/js/Editor.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,9 +10,7 @@ import * as sheetsUtils from './sefaria/sheetsUtils'

import {
SheetMetaDataBox,
SheetAuthorStatement,
SheetTitle,
CollectionStatement,
InterfaceText,
Autocompleter,
} from './Misc';
Expand All @@ -21,6 +19,7 @@ import {ProfilePic} from "./ProfilePic";
import classNames from 'classnames';
import $ from "./sefaria/sefariaJquery";
import ReactDOM from "react-dom";
import {SheetOptions} from "./sheets/SheetOptions";

// Mapping from Sheet doc format source types to Slate block element types
const sheet_item_els = {
Expand Down Expand Up @@ -597,7 +596,7 @@ function transformSheetJsonToSlate(sheet) {
let initValue = [
{
type: 'Sheet',
status: sheet.status,
status: status,
views: sheet.views,
tags: sheet.tags || [],
includedRefs: sheet.includedRefs,
Expand Down Expand Up @@ -2546,24 +2545,20 @@ const BlockButton = ({format, icon}) => {
}

const SefariaEditor = (props) => {
const editorContainer = useRef();
const editorContainer = useRef(null);
const [sheet, setSheet] = useState(props.data);
const [status, setStatus] = useState(sheet?.status || "unlisted");
const initValue = [{type: "sheet", children: [{text: ""}]}];
const renderElement = useCallback(props => <Element {...props}/>, []);
const [value, setValue] = useState(initValue);
const [currentDocument, setCurrentDocument] = useState(initValue);
const [unsavedChanges, setUnsavedChanges] = useState(false);
const [lastModified, setlastModified] = useState(props.data.dateModified);
const [canUseDOM, setCanUseDOM] = useState(false);
const [lastSelection, setLastSelection] = useState(null)
const [readyForNormalize, setReadyForNormalize] = useState(false);
const [summary, setSummary] = useState(sheet.summary || "");
const [title, setTitle] = useState(sheet.title || "");

useEffect(() => {
saveDocument(currentDocument);
}, [title, summary]);

useEffect(
() => {
if (!canUseDOM) {
Expand All @@ -2572,7 +2567,7 @@ const SefariaEditor = (props) => {

setUnsavedChanges(true);
// Update debounced value after delay
const handler = setTimeout(() => {
const handler = setTimeout( () => {
saveDocument(currentDocument);
}, 500);

Expand All @@ -2583,7 +2578,7 @@ const SefariaEditor = (props) => {
clearTimeout(handler);
};
},
[currentDocument[0].children[0]] // Only re-call effect if value or delay changes
[currentDocument[0].children[0], title, summary] // Only re-call effect if value or delay changes
);

useEffect(
Expand All @@ -2599,6 +2594,7 @@ const SefariaEditor = (props) => {

//TODO: Check that we still need/want this temporary analytics tracking code
try {hj('event', 'using_new_editor');} catch {console.error('hj failed')}

}, []
)

Expand Down Expand Up @@ -2633,7 +2629,7 @@ const SefariaEditor = (props) => {
if (node.text && props.divineNameReplacement) {
const newStr = replaceDivineNames(node.text, props.divineNameReplacement)
if (newStr != node.text) {
Transforms.insertText(editor, newStr, { at: path })
Transforms.insertText(editor, newStr, {at: path})
}
}
}
Expand All @@ -2644,8 +2640,8 @@ const SefariaEditor = (props) => {
const temp_select = editor.selection

Transforms.select(editor, {
anchor: {path: [0, 0], offset: 0},
focus: {path: [0, 0], offset: 0},
anchor: {path: [0, 0], offset: 0},
focus: {path: [0, 0], offset: 0},
});

Transforms.select(editor, temp_select)
Expand Down Expand Up @@ -2768,7 +2764,7 @@ const SefariaEditor = (props) => {

});
let sheet = {
status: doc.status,
status: status,
id: doc.id,
promptedToPublish: doc.promptedToPublish,
lastModified: lastModified,
Expand All @@ -2780,28 +2776,33 @@ const SefariaEditor = (props) => {
sources: sources.filter(x => !!x),
nextNode: doc.nextNode,
};

return JSON.stringify(sheet);

return sheet;
}


function saveDocument(doc) {
function getLastModified() {
return Sefaria.sheets._loadSheetByID[props.data.id]?.dateModified || props.data.dateModified;
}
async function saveDocument(doc) {
const lastModified = getLastModified();
const json = saveSheetContent(doc[0], lastModified);
if (!json) {
return
}
// console.log('saving...');
try {
await postSheet(json);
} catch(error) {
console.log(`Error: ${error.message}`)
}
}

$.post("/api/sheets/", {"json": json}, res => {
setlastModified(res.dateModified);
// console.log("saved at: "+ res.dateModified);
setUnsavedChanges(false);
setTitle(res.title);
setSummary(res.summary);
const updatedSheet = {...Sefaria.sheets._loadSheetByID[doc[0].id], ...res};
Sefaria.sheets._loadSheetByID[doc[0].id] = updatedSheet
});
const postSheet = async (sheet) => {
const data = await Sefaria.apiRequestWithBody("/api/sheets/", null, sheet, "POST");
setStatus(data.status);
setTitle(data.title);
setSummary(data.summary);
const updatedSheet = {...Sefaria.sheets._loadSheetByID[props.data.id], ...data};
Sefaria.sheets._loadSheetByID[props.data.id] = updatedSheet;
}

function onChange(value) {
Expand Down Expand Up @@ -2950,18 +2951,26 @@ const SefariaEditor = (props) => {
() => withTables(withSefariaSheet(withLinks(withHistory(withReact(createEditor()))))),
[]
);

const sheetOptions = <SheetOptions toggleSignUpModal={props.toggleSignUpModal}
sheetID={sheet.id}
postSheet={postSheet}
historyObject={props.historyObject}
editable={true}
authorUrl={sheet.ownerProfileUrl}
status={status}
handleCollectionsChange={props.handleCollectionsChange}
/>;
return (
<div ref={editorContainer} onClick={props.handleClick} className="text">
<SheetMetaDataBox authorStatement={props.authorStatement}
authorUrl={props.authorUrl}
authorImage={props.authorImage}
title={props.title}
summary={props.summary}
<SheetMetaDataBox authorStatement={sheet.ownerName}
authorUrl={sheet.ownerProfileUrl}
authorImage={sheet.ownerImageUrl}
title={title}
summary={summary}
editable={true}
titleCallback={(newTitle) => setTitle(newTitle)}
summaryCallback={(newSummary) => setSummary(newSummary)}
sheetOptions={props.sheetOptions}/>
sheetOptions={sheetOptions}/>
{
/* debugger */

Expand Down
1 change: 0 additions & 1 deletion static/js/NavSidebar.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -730,7 +730,6 @@ const GetStartedButton = () => {
return <Button className="getStartedSheets" onClick={() => window.location.href=href}>Get Started</Button>;
}
const CreateSheetsButton = () => {
// #sheetsButton
return <Button icon={"/static/icons/new-sheet-black.svg"} className="small" onClick={() => window.location.href="/sheets/new"}>Create</Button>
}
const CreateASheet = () => (
Expand Down
2 changes: 1 addition & 1 deletion static/js/UserProfile.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -540,7 +540,7 @@ const UserBackground = ({profile: p, showBio}) => {
</span>
);
}
const aboutMe = <div className="title sub-title" dangerouslySetInnerHTML={{ __html: p.bio }}/>;
const aboutMe = <div className="title sub-title" dangerouslySetInnerHTML={{ __html: p.bio }}/>; // Bio/"About Me" is the only field in profile with HTML
const subTitle = <div className="title sub-title">
<span>{p.position}</span>
{p.position && p.organization ? <span>{Sefaria._(" at ")}</span> : null}
Expand Down
Loading
Loading