liquid_feedback_frontend

view env/ui/field/wysihtml.lua @ 1502:56209dc74a9c

Added image upload to form
author bsw
date Mon Jun 08 13:58:26 2020 +0200 (2020-06-08)
parents 32cc544d5a5b
children fce3409bc9b0
line source
1 function ui.field.wysihtml(args)
3 local toolbar = {
4 { command = "bold", title ="CTRL+B", icon = "format_bold" },
5 { command = "italic", title ="CTRL+I", icon = "format_italic" },
6 { command = "createLink", icon = "insert_link" },
7 { command = "removeLink", icon = "insert_link", crossed = "\\" },
8 { command = "insertImage", icon = "insert_image" },
9 { command = "formatBlock", command_value = "h1", icon = "title", head_level = "1" },
10 { command = "formatBlock", command_value = "h2", icon = "title", head_level = "2" },
11 { command = "formatBlock", command_value = "h3", icon = "title", head_level = "3" },
12 { command = "formatBlock", command_blank = "true", icon = "format_clear" },
13 { command = "insertBlockQuote", icon = "format_quote" },
14 { command = "insertUnorderedList", icon = "format_list_bulleted" },
15 { command = "insertOrderedList", icon = "format_list_numbered" },
16 { command = "outdentList", icon = "format_indent_decrease" },
17 { command = "indentList", icon = "format_indent_increase" },
18 -- { command = "alignLeftStyle", icon = "format_align_left" },
19 -- { command = "alignRightStyle", icon = "format_align_right" },
20 -- { command = "alignCenterStyle", icon = "format_align_center" },
21 { command = "undo", icon = "undo" },
22 { command = "redo", icon = "redo" }
23 }
25 slot.put([[
26 <style>
27 #wysihtml-html-button {
28 padding: 2px;
29 vertical-align: bottom;
30 }
31 #wysihtml-html-button.wysihtml-action-active {
32 color: #fff;
33 background: #000;
34 }
35 </style>
36 ]])
38 ui.container{ attr = { id = "toolbar", class = "toolbar", style = "display: none;" }, content = function()
39 for i, t in ipairs(toolbar) do
40 ui.tag{ tag = "a", attr = { ["data-wysihtml-command"] = t.command, ["data-wysihtml-command-value"] = t.command_value, ["data-wysihtml-command-blank-value"] = t.command_blank, title = t.shortcut }, content = function()
41 ui.tag{ tag = "i", attr = { class = "material-icons" }, content = t.icon }
42 if t.crossed then
43 ui.tag{ attr = { class = "crossed" }, content = t.crossed }
44 end
45 if t.head_level then
46 ui.tag{ attr = { class = "head_level" }, content = t.head_level }
47 end
48 end }
49 end
50 slot.put([[
51 <div data-wysihtml-dialog="createLink" style="display: none;">
52 <label>
53 Link:
54 <input data-wysihtml-dialog-field="href" value="http://">
55 </label>
56 <a data-wysihtml-dialog-action="save">OK</a>&nbsp;<a data-wysihtml-dialog-action="cancel">Cancel</a>
57 </div>
59 <div data-wysihtml-dialog="insertImage" style="display: none;">
60 <label>
61 Image:
62 <input data-wysihtml-dialog-field="src" value="http://">
63 </label>
64 <label>
65 Align:
66 <select data-wysihtml-dialog-field="className">
67 <option value="">default</option>
68 <option value="wysiwyg-float-left">left</option>
69 <option value="wysiwyg-float-right">right</option>
70 </select>
71 </label>
72 <a data-wysihtml-dialog-action="save">OK</a>&nbsp;<a data-wysihtml-dialog-action="cancel">Cancel</a>
73 </div>
75 ]])
76 slot.put([[ <a id="wysihtml-html-button" data-wysihtml-action="change_view">]] .. _"expert editor (HTML)" .. [[</a> ]])
77 end }
79 ui.field.text(args)
81 ui.tag{ tag = "script", attr = { src = request.get_absolute_baseurl() .. "static/wysihtml/wysihtml.js" }, content = "" }
82 ui.tag{ tag = "script", attr = { src = request.get_absolute_baseurl() .. "static/wysihtml/wysihtml.all-commands.js" }, content = "" }
83 ui.tag{ tag = "script", attr = { src = request.get_absolute_baseurl() .. "static/wysihtml/wysihtml.toolbar.js" }, content = "" }
84 ui.tag{ tag = "script", attr = { src = request.get_absolute_baseurl() .. "static/wysihtml/wysihtml_liquidfeedback_rules.js" }, content = "" }
85 ui.script{ script = [[
86 function initEditor() {
87 var editor = new wysihtml.Editor("]] .. args.attr.id .. [[", {
88 toolbar: "toolbar",
89 parserRules: wysihtmlParserRules,
90 useLineBreaks: true
91 });
92 }
93 if(window.addEventListener){
94 window.addEventListener('load', initEditor, false);
95 } else {
96 window.attachEvent('onload', initEditor);
97 }
98 ]] }
100 end

Impressum / About Us