aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--package.json1
-rw-r--r--src/client/util/RichTextSchema.tsx11
-rw-r--r--src/client/util/TooltipTextMenu.tsx61
-rw-r--r--src/client/views/collections/CollectionSchemaView.scss5
-rw-r--r--src/server/public/files/upload_1b4818f39ea324b5a687bb1ade3dca6c.jpgbin0 -> 26946 bytes
-rw-r--r--src/server/public/files/upload_1f1c6cfef33e5992fa860802e8c466a7.jpgbin0 -> 45309 bytes
-rw-r--r--src/server/public/files/upload_2045f363aa9cf281407703ca242aad1a.jpgbin0 -> 9009 bytes
-rw-r--r--src/server/public/files/upload_25bffd90c080c27f5ac822984406b958.jpgbin0 -> 43534 bytes
-rw-r--r--src/server/public/files/upload_261f11dc39ad568212b5c7e39d1e6d13.jpgbin0 -> 27259 bytes
-rw-r--r--src/server/public/files/upload_26bcc62639141ba64e603daebb5bf5d3.pngbin0 -> 2757327 bytes
-rw-r--r--src/server/public/files/upload_2d77d0773612e4723b78118ac50a2929.jpgbin0 -> 1805512 bytes
-rw-r--r--src/server/public/files/upload_2de9ad4dc687c53760c39f724c9a08a5.jpgbin0 -> 77462 bytes
-rw-r--r--src/server/public/files/upload_4abb568aa7cce9d291532c3d0da97102.jpgbin0 -> 22445 bytes
-rw-r--r--src/server/public/files/upload_54c34aaca5a7bf510cebad461ec39512.pngbin0 -> 2757327 bytes
-rw-r--r--src/server/public/files/upload_562b1e527300df8b350eeab094b3e1f1.jpgbin0 -> 15988 bytes
-rw-r--r--src/server/public/files/upload_6a26d3f7008a8c79ee5fc8054ba69996.jpgbin0 -> 45025 bytes
-rw-r--r--src/server/public/files/upload_70fa5e0c3f393504349d5865e28f4cac.jpgbin0 -> 18041 bytes
-rw-r--r--src/server/public/files/upload_8155b5b0f57da107bb07083c04e78943.jpgbin0 -> 31103 bytes
-rw-r--r--src/server/public/files/upload_88f588574e0efc415186af935114af9a.jpgbin0 -> 40249 bytes
-rw-r--r--src/server/public/files/upload_8d1c253f93f77c69c0c04ae3efb7d714.pngbin0 -> 2757327 bytes
-rw-r--r--src/server/public/files/upload_9ef80158609f5ff739087aecad367b9d.jpgbin0 -> 28523 bytes
-rw-r--r--src/server/public/files/upload_c39a7e0d7e8d35bb18461a5a0aa063bf.jpgbin0 -> 13811 bytes
-rw-r--r--src/server/public/files/upload_c6b81ab4eb70465a7e9b45d5c8f3ecaa.jpgbin0 -> 28566 bytes
-rw-r--r--src/server/public/files/upload_c99ec7a8a2df0b2f90479fde7d70c2eb.jpgbin0 -> 21995 bytes
-rw-r--r--src/server/public/files/upload_cec1cfcc67cfe5889de4098a49fec45e.jpgbin0 -> 22125 bytes
-rw-r--r--src/server/public/files/upload_f27688fe92dc7de398e957e5d96e1a22.jpgbin0 -> 18964 bytes
26 files changed, 61 insertions, 17 deletions
diff --git a/package.json b/package.json
index e0d0a72dd..135bd4a91 100644
--- a/package.json
+++ b/package.json
@@ -68,6 +68,7 @@
"@types/prosemirror-history": "^1.0.1",
"@types/prosemirror-inputrules": "^1.0.2",
"@types/prosemirror-keymap": "^1.0.1",
+ "@types/prosemirror-menu": "^1.0.1",
"@types/prosemirror-model": "^1.7.0",
"@types/prosemirror-schema-basic": "^1.0.1",
"@types/prosemirror-schema-list": "^1.0.1",
diff --git a/src/client/util/RichTextSchema.tsx b/src/client/util/RichTextSchema.tsx
index 2a3c1da6e..489c22a57 100644
--- a/src/client/util/RichTextSchema.tsx
+++ b/src/client/util/RichTextSchema.tsx
@@ -9,7 +9,6 @@ import { EditorView, } from "prosemirror-view";
const pDOM: DOMOutputSpecArray = ["p", 0], blockquoteDOM: DOMOutputSpecArray = ["blockquote", 0], hrDOM: DOMOutputSpecArray = ["hr"],
preDOM: DOMOutputSpecArray = ["pre", ["code", 0]], brDOM: DOMOutputSpecArray = ["br"], ulDOM: DOMOutputSpecArray = ["ul", 0]
-
// :: Object
// [Specs](#model.NodeSpec) for the nodes defined in this schema.
export const nodes: { [index: string]: NodeSpec } = {
@@ -222,7 +221,15 @@ export const marks: { [index: string]: MarkSpec } = {
code: {
parseDOM: [{ tag: "code" }],
toDOM() { return codeDOM }
- }
+ },
+
+
+ timesNewRoman: {
+ parseDOM: [{ style: 'font-family: "Times New Roman", Times, serif;' }],
+ toDOM: () => ['span', {
+ style: 'font-family: "Times New Roman", Times, serif;'
+ }]
+ },
}
// :: Schema
diff --git a/src/client/util/TooltipTextMenu.tsx b/src/client/util/TooltipTextMenu.tsx
index 913472aa0..82e9d1bac 100644
--- a/src/client/util/TooltipTextMenu.tsx
+++ b/src/client/util/TooltipTextMenu.tsx
@@ -1,23 +1,29 @@
import { action, IReactionDisposer, reaction } from "mobx";
-import { baseKeymap } from "prosemirror-commands";
+import { Dropdown, DropdownSubmenu, MenuItem } from "prosemirror-menu";
+import { baseKeymap, lift } from "prosemirror-commands";
import { history, redo, undo } from "prosemirror-history";
import { keymap } from "prosemirror-keymap";
import { EditorState, Transaction, NodeSelection } from "prosemirror-state";
import { EditorView } from "prosemirror-view";
import { schema } from "./RichTextSchema";
-import { Schema, NodeType } from "prosemirror-model"
-import React = require("react")
+import { Schema, NodeType } from "prosemirror-model";
+import React = require("react");
import "./TooltipTextMenu.scss";
const { toggleMark, setBlockType, wrapIn } = require("prosemirror-commands");
import { library } from '@fortawesome/fontawesome-svg-core'
-import { wrapInList, bulletList } from 'prosemirror-schema-list'
-import { faListUl } from '@fortawesome/free-solid-svg-icons';
+import { wrapInList, bulletList, liftListItem, listItem } from 'prosemirror-schema-list'
+import {
+ faListUl,
+} from '@fortawesome/free-solid-svg-icons';
+import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
+const SVG = "http://www.w3.org/2000/svg"
//appears above a selection of text in a RichTextBox to give user options such as Bold, Italics, etc.
export class TooltipTextMenu {
private tooltip: HTMLElement;
+ private num_icons = 0;
constructor(view: EditorView) {
this.tooltip = document.createElement("div");
@@ -37,20 +43,29 @@ export class TooltipTextMenu {
{ command: toggleMark(schema.marks.strikethrough), dom: this.icon("S", "strikethrough") },
{ command: toggleMark(schema.marks.superscript), dom: this.icon("s", "superscript") },
{ command: toggleMark(schema.marks.subscript), dom: this.icon("s", "subscript") },
- //this doesn't work currently - look into notion of active block
{ command: wrapInList(schema.nodes.bullet_list), dom: this.icon(":", "bullets") },
+ { command: toggleMark(schema.marks.timesNewRoman), dom: this.icon("x", "TNR") },
+ { command: lift, dom: this.icon("<", "lift") },
]
- items.forEach(({ dom }) => this.tooltip.appendChild(dom));
+ //add menu items
+ items.forEach(({ dom, command }) => {
+ this.tooltip.appendChild(dom);
+ });
+
+ //add dropdowns
//pointer down handler to activate button effects
this.tooltip.addEventListener("pointerdown", e => {
e.preventDefault();
view.focus();
+ //update view of icons
+ this.num_icons = 0;
items.forEach(({ command, dom }) => {
- if (dom.contains(e.target as Node)) {
+ if (e.srcElement && dom.contains(e.srcElement as Node)) {
+ //let active = command(view.state, view.dispatch, view);
let active = command(view.state, view.dispatch, view);
//uncomment this if we want the bullet button to disappear if current selection is bulleted
- // dom.style.display = active ? "" : "none"
+ //dom.style.display = active ? "" : "none";
}
})
})
@@ -88,9 +103,24 @@ export class TooltipTextMenu {
//this doesn't currently work but could be used to use icons for buttons
unorderedListIcon(): HTMLSpanElement {
let span = document.createElement("span");
- let icon = document.createElement("FontAwesomeIcon");
- icon.className = "menuicon fa fa-smile-o";
- span.appendChild(icon);
+ //let icon = document.createElement("FontAwesomeIcon");
+ //icon.className = "menuicon";
+ //icon.style.color = "white";
+ //span.appendChild(<i style={{ color: "white" }} icon="list-ul" size="lg" />);
+ let i = document.createElement("i");
+ i.className = "fa falist-ul";
+ span.appendChild(i);
+ //span.appendChild(icon);
+ //return liftItem.spec.icon.sty
+
+ //let sym = document.createElementNS(SVG, "symbol")
+ // sym.id = name
+ //sym.style.color = "white";
+ //width then height
+ //sym.setAttribute("viewBox", "0 0 " + 1024 + " " + 1024);
+ //let path = sym.appendChild(document.createElementNS(SVG, "path"));
+ //path.setAttribute("d", "M219 310v329q0 7-5 12t-12 5q-8 0-13-5l-164-164q-5-5-5-13t5-13l164-164q5-5 13-5 7 0 12 5t5 12zM1024 749v109q0 7-5 12t-12 5h-987q-7 0-12-5t-5-12v-109q0-7 5-12t12-5h987q7 0 12 5t5 12zM1024 530v109q0 7-5 12t-12 5h-621q-7 0-12-5t-5-12v-109q0-7 5-12t12-5h621q7 0 12 5t5 12zM1024 310v109q0 7-5 12t-12 5h-621q-7 0-12-5t-5-12v-109q0-7 5-12t12-5h621q7 0 12 5t5 12zM1024 91v109q0 7-5 12t-12 5h-987q-7 0-12-5t-5-12v-109q0-7 5-12t12-5h987q7 0 12 5t5 12z");
+ //span.appendChild(sym);
return span;
}
@@ -125,13 +155,14 @@ export class TooltipTextMenu {
// crossing lines, end may be more to the left)
let left = Math.max((start.left + end.left) / 2, start.left + 3)
this.tooltip.style.left = (left - box.left) + "px"
- let width = Math.abs(start.left - end.left) / 2;
+ //let width = Math.abs(start.left - end.left) / 2;
+ let width = 8 * 16 + 15;
let mid = Math.min(start.left, end.left) + width;
//THIS WIDTH IS 15 * NUMBER OF ICONS + 15
- this.tooltip.style.width = 122 + "px";
+ this.tooltip.style.width = width + "px";
this.tooltip.style.bottom = (box.bottom - start.top) + "px";
}
destroy() { this.tooltip.remove() }
-} \ No newline at end of file
+}
diff --git a/src/client/views/collections/CollectionSchemaView.scss b/src/client/views/collections/CollectionSchemaView.scss
index c3a2e88ac..9cd6c8a39 100644
--- a/src/client/views/collections/CollectionSchemaView.scss
+++ b/src/client/views/collections/CollectionSchemaView.scss
@@ -15,6 +15,11 @@
padding: 0px;
font-size: 100%;
}
+
+ul {
+ list-style-type: disc;
+}
+
#schema-options-header {
text-align: center;
padding: 0px;
diff --git a/src/server/public/files/upload_1b4818f39ea324b5a687bb1ade3dca6c.jpg b/src/server/public/files/upload_1b4818f39ea324b5a687bb1ade3dca6c.jpg
new file mode 100644
index 000000000..aeb10c4b0
--- /dev/null
+++ b/src/server/public/files/upload_1b4818f39ea324b5a687bb1ade3dca6c.jpg
Binary files differ
diff --git a/src/server/public/files/upload_1f1c6cfef33e5992fa860802e8c466a7.jpg b/src/server/public/files/upload_1f1c6cfef33e5992fa860802e8c466a7.jpg
new file mode 100644
index 000000000..a2c1d8a46
--- /dev/null
+++ b/src/server/public/files/upload_1f1c6cfef33e5992fa860802e8c466a7.jpg
Binary files differ
diff --git a/src/server/public/files/upload_2045f363aa9cf281407703ca242aad1a.jpg b/src/server/public/files/upload_2045f363aa9cf281407703ca242aad1a.jpg
new file mode 100644
index 000000000..c19b31a38
--- /dev/null
+++ b/src/server/public/files/upload_2045f363aa9cf281407703ca242aad1a.jpg
Binary files differ
diff --git a/src/server/public/files/upload_25bffd90c080c27f5ac822984406b958.jpg b/src/server/public/files/upload_25bffd90c080c27f5ac822984406b958.jpg
new file mode 100644
index 000000000..3614b42eb
--- /dev/null
+++ b/src/server/public/files/upload_25bffd90c080c27f5ac822984406b958.jpg
Binary files differ
diff --git a/src/server/public/files/upload_261f11dc39ad568212b5c7e39d1e6d13.jpg b/src/server/public/files/upload_261f11dc39ad568212b5c7e39d1e6d13.jpg
new file mode 100644
index 000000000..ecd12d9cb
--- /dev/null
+++ b/src/server/public/files/upload_261f11dc39ad568212b5c7e39d1e6d13.jpg
Binary files differ
diff --git a/src/server/public/files/upload_26bcc62639141ba64e603daebb5bf5d3.png b/src/server/public/files/upload_26bcc62639141ba64e603daebb5bf5d3.png
new file mode 100644
index 000000000..e2297cb3c
--- /dev/null
+++ b/src/server/public/files/upload_26bcc62639141ba64e603daebb5bf5d3.png
Binary files differ
diff --git a/src/server/public/files/upload_2d77d0773612e4723b78118ac50a2929.jpg b/src/server/public/files/upload_2d77d0773612e4723b78118ac50a2929.jpg
new file mode 100644
index 000000000..261a0ceff
--- /dev/null
+++ b/src/server/public/files/upload_2d77d0773612e4723b78118ac50a2929.jpg
Binary files differ
diff --git a/src/server/public/files/upload_2de9ad4dc687c53760c39f724c9a08a5.jpg b/src/server/public/files/upload_2de9ad4dc687c53760c39f724c9a08a5.jpg
new file mode 100644
index 000000000..6b6ec3c3f
--- /dev/null
+++ b/src/server/public/files/upload_2de9ad4dc687c53760c39f724c9a08a5.jpg
Binary files differ
diff --git a/src/server/public/files/upload_4abb568aa7cce9d291532c3d0da97102.jpg b/src/server/public/files/upload_4abb568aa7cce9d291532c3d0da97102.jpg
new file mode 100644
index 000000000..f6332670c
--- /dev/null
+++ b/src/server/public/files/upload_4abb568aa7cce9d291532c3d0da97102.jpg
Binary files differ
diff --git a/src/server/public/files/upload_54c34aaca5a7bf510cebad461ec39512.png b/src/server/public/files/upload_54c34aaca5a7bf510cebad461ec39512.png
new file mode 100644
index 000000000..e2297cb3c
--- /dev/null
+++ b/src/server/public/files/upload_54c34aaca5a7bf510cebad461ec39512.png
Binary files differ
diff --git a/src/server/public/files/upload_562b1e527300df8b350eeab094b3e1f1.jpg b/src/server/public/files/upload_562b1e527300df8b350eeab094b3e1f1.jpg
new file mode 100644
index 000000000..db40705dd
--- /dev/null
+++ b/src/server/public/files/upload_562b1e527300df8b350eeab094b3e1f1.jpg
Binary files differ
diff --git a/src/server/public/files/upload_6a26d3f7008a8c79ee5fc8054ba69996.jpg b/src/server/public/files/upload_6a26d3f7008a8c79ee5fc8054ba69996.jpg
new file mode 100644
index 000000000..f0417a752
--- /dev/null
+++ b/src/server/public/files/upload_6a26d3f7008a8c79ee5fc8054ba69996.jpg
Binary files differ
diff --git a/src/server/public/files/upload_70fa5e0c3f393504349d5865e28f4cac.jpg b/src/server/public/files/upload_70fa5e0c3f393504349d5865e28f4cac.jpg
new file mode 100644
index 000000000..395f8ec21
--- /dev/null
+++ b/src/server/public/files/upload_70fa5e0c3f393504349d5865e28f4cac.jpg
Binary files differ
diff --git a/src/server/public/files/upload_8155b5b0f57da107bb07083c04e78943.jpg b/src/server/public/files/upload_8155b5b0f57da107bb07083c04e78943.jpg
new file mode 100644
index 000000000..53d9315a9
--- /dev/null
+++ b/src/server/public/files/upload_8155b5b0f57da107bb07083c04e78943.jpg
Binary files differ
diff --git a/src/server/public/files/upload_88f588574e0efc415186af935114af9a.jpg b/src/server/public/files/upload_88f588574e0efc415186af935114af9a.jpg
new file mode 100644
index 000000000..b72dbc482
--- /dev/null
+++ b/src/server/public/files/upload_88f588574e0efc415186af935114af9a.jpg
Binary files differ
diff --git a/src/server/public/files/upload_8d1c253f93f77c69c0c04ae3efb7d714.png b/src/server/public/files/upload_8d1c253f93f77c69c0c04ae3efb7d714.png
new file mode 100644
index 000000000..e2297cb3c
--- /dev/null
+++ b/src/server/public/files/upload_8d1c253f93f77c69c0c04ae3efb7d714.png
Binary files differ
diff --git a/src/server/public/files/upload_9ef80158609f5ff739087aecad367b9d.jpg b/src/server/public/files/upload_9ef80158609f5ff739087aecad367b9d.jpg
new file mode 100644
index 000000000..84423538c
--- /dev/null
+++ b/src/server/public/files/upload_9ef80158609f5ff739087aecad367b9d.jpg
Binary files differ
diff --git a/src/server/public/files/upload_c39a7e0d7e8d35bb18461a5a0aa063bf.jpg b/src/server/public/files/upload_c39a7e0d7e8d35bb18461a5a0aa063bf.jpg
new file mode 100644
index 000000000..dc7ec2f33
--- /dev/null
+++ b/src/server/public/files/upload_c39a7e0d7e8d35bb18461a5a0aa063bf.jpg
Binary files differ
diff --git a/src/server/public/files/upload_c6b81ab4eb70465a7e9b45d5c8f3ecaa.jpg b/src/server/public/files/upload_c6b81ab4eb70465a7e9b45d5c8f3ecaa.jpg
new file mode 100644
index 000000000..4422124a1
--- /dev/null
+++ b/src/server/public/files/upload_c6b81ab4eb70465a7e9b45d5c8f3ecaa.jpg
Binary files differ
diff --git a/src/server/public/files/upload_c99ec7a8a2df0b2f90479fde7d70c2eb.jpg b/src/server/public/files/upload_c99ec7a8a2df0b2f90479fde7d70c2eb.jpg
new file mode 100644
index 000000000..3747ca985
--- /dev/null
+++ b/src/server/public/files/upload_c99ec7a8a2df0b2f90479fde7d70c2eb.jpg
Binary files differ
diff --git a/src/server/public/files/upload_cec1cfcc67cfe5889de4098a49fec45e.jpg b/src/server/public/files/upload_cec1cfcc67cfe5889de4098a49fec45e.jpg
new file mode 100644
index 000000000..95053d772
--- /dev/null
+++ b/src/server/public/files/upload_cec1cfcc67cfe5889de4098a49fec45e.jpg
Binary files differ
diff --git a/src/server/public/files/upload_f27688fe92dc7de398e957e5d96e1a22.jpg b/src/server/public/files/upload_f27688fe92dc7de398e957e5d96e1a22.jpg
new file mode 100644
index 000000000..9841bad3f
--- /dev/null
+++ b/src/server/public/files/upload_f27688fe92dc7de398e957e5d96e1a22.jpg
Binary files differ