bergie / hallo Goto Github PK
View Code? Open in Web Editor NEWSimple rich text editor (contentEditable) for jQuery UI
Home Page: http://hallojs.org/
License: MIT License
Simple rich text editor (contentEditable) for jQuery UI
Home Page: http://hallojs.org/
License: MIT License
This is the reason the link dialog is not working: the current selection is lost when the dialog is opened.
Would be nice to have a (dropdown?) font size plugin.
in #36 we merged the WIP for the image plugin to hallo. this is one of the tasks that remain to do:
the search result html area should be generalized, showResults could be abstracted to work for both suggestions and search. it should be the same for search and suggestions (suggestion is missing paging right now).
maybe we should even allow injecting tabs into the imageplugin. somebody might need a browse tab with a directory-like structure, or something we can't imagine yet...
This can be seen on http://createjs.org If you click into the first paragraph, and click the UL button twice, the layout will not revert back to the original, because the p tag is not restored
That'd be a nice to have! People are lazy and wanna try it quickly before cloning. At least I'm this kind of guy.
in #36 we merged the WIP for the image plugin to hallo. this is one of the tasks that remain to do:
dialog closes right again if the editor is not created with showAlways: true
in #36 we merged the WIP for the image plugin to hallo. this is one of the tasks that remain to do:
on save, the drag+drop elements should be stripped out of the content that is stored through the backbone. currently the ui-draggable attributes and with bad timing even the blue blocks get stored.
Hey Henri,
Would you be interested in joining me to do the jQuery UI stuff for Aloha Editor? I'm thinking we can prototype the jQuery UI widgets in their own MIT licensed repository, such that they can be used by Hallo and Aloha Editor and whatever else needs them. This work will start end of this month, or start of next month.
When I have a hyperlink in an editable area (especially one that covers the entire editable area), and I try to click on the text to get a cursor for editing, the browser follows the href atribute instead and takes me to the link target. This only happens after saving the content and editing again. At the time you insert the link, you are still able to get a text cursor, but afterwards this is impossible
Make it possible to add linebreaks for button bars so you can have more than one line of buttons
We should clean up HTML generated by browser's contentEditable implementation, especially when pasting. Sanitize.js might be a good option for this.
When user accepts an annotation it is written to DOM. However, this doesn't fire hallomodified.
Font Awesome would give us very nice icons for the editor buttons. The licensing seems very compatible:
The Font Awesome webfont, CSS, and LESS files are licensed under CC BY 3.0: http://creativecommons.org/licenses/by/3.0/ A mention of 'Font Awesome - http://fortawesome.github.com/Font-Awesome' in human-readable source code is considered acceptable attribution (most common on the web). If human readable source code is not available to the end user, a mention in an 'About' or 'Credits' screen is considered acceptable (most common in desktop or mobile software).
When Hallo has been enabled, and later disabled, it still listens for events on the element. This causes errors:
Component returned failure code: 0x80004005 (NS_ERROR_FAILURE) [nsIDOMHTMLDocument.queryCommandState]
[Break On This Error] if (document.queryCommandState(format)) {
On Firefox, the Hallo toolbar is always shown regardless of whether there is a selection or not.
[balupton@localhost hallo]$ coffee -c -o examples *.coffee
[balupton@localhost hallo]$ ls
examples format.coffee hallo.coffee README.md
[balupton@localhost hallo]$ coffee *.coffee
ReferenceError: jQuery is not defined
at Object. (/home/balupton/Work/hallo/format.coffee:3:3)
at Object. (/home/balupton/Work/hallo/format.coffee:47:4)
at Module._compile (module.js:404:26)
at Object.run (/usr/local/lib/node_modules/coffee-script/lib/coffee-script.js:62:19)
at /usr/local/lib/node_modules/coffee-script/lib/command.js:120:29
at /usr/local/lib/node_modules/coffee-script/lib/command.js:90:26
at [object Object]. (fs.js:107:5)
at [object Object].emit (events.js:61:17)
at afterRead (fs.js:878:12)
at wrapper (fs.js:245:17)
[balupton@localhost hallo]$
In Chrome I see a lot of:
http://creativecommons.org/ns#license> doesn't have a namespace definition in '
Object
Which also causes Firefox to crash.
Add tabs to links as well
the VieBundle link plugin has them, see http://cmf.liip.ch/ and https://github.com/liip/LiipVieBundle/blob/8afac2c58bbf68d962d8e059b8b2ce754dbb9e3d/Resources/halloplugins/link.js (though the standbol handling is still outside everything, guess the code is more for the idea than actual reuse)
Content returned by Hallo's getContents
method includes non-accepted annotations from annotate plugin, for example:
This means creating the new generation of <span class="entity organisation withSuggestions">Content Management</span> interfaces in the <span class="entity organisation">IKS Project</span>
These should be cleaned up in getContents phase.
in #36 we merged the WIP for the image plugin to hallo. this is one of the tasks that remain to do:
the tabs in the dialog are somehow handmade instead of using jquery-ui. as a result, if the first tab is not visible (as in the example) there is no content at all => use a jquery-ui tab plugin if there is a reasonable one. => http://jqueryui.com/demos/tabs/
In normal writing mode there should be no toolbar to distract user. Formatting could be provided as a separate popover when user actually makes selections.
The Byword writing app for Mac is a great example of this concept: http://minimalmac.com/post/3855002258/byword
There should be a +
button in the Hallo toolbar that allows users to insert new content to the page, including images and tables.
As the menu is available only on selection, we could also listen to double clicks and bring the menu up on them.
Rather than being a 2-pane editor, the Markdown mode should format the elements in place (much like http://iawriter.com ).
When a line starts with a #, that line is then styled as heading one (and still has the pound in front of it). Likewise with * for lists, and links should also be autolinked.
Hello,
I'm trying out hallo in my project and I'm getting some odd error messages. This is my integration code:
$('#edit_icon_id').click(function() {
$('#div_id').hallo({
plugins: {
'halloformat': {}
}
});
});
When I click the #edit_icon_id for the first time, I get following error:
(new String("cannot call methods on halloformat prior to initialization; attempted to call method 'cleanupContentClone'"))
After that, every time I click #edit_icon_id I get this error:
(new TypeError("this.toolbar is null", "http://localhost/resources/js/hallo-min.js", 7))
Also note, when I call only $('#div_id').hallo();
it works, but without toolbar so I can't format contents... :S
I just tried building hallo, so I entered
cake build
in my shell. Ubuntu then told me that cake is not installed and that I can install it with
apt-get install cakephp-scripts
I did that and afterwards I get some other error (BuildShell can't be found or something). I assume that "cake" in the README refers to something else, because it would be strange if a coffeescript codebase needs some PHP framework to build it, but I know nothing about coffeescript, so I couldn't really figure it out. It would be nice if the instructions could be a bit more precise.
When user is writing content, we should allow at least parts of the Markdown microsyntax for formatting. The microsyntax should be converted to HTML immediately when inputted.
So, for example writing # Hello...
would immediately by turned into <h1>Hello...</h1>
.
This would be great for power users, as then they wouldn't need obscure keyboard shortcuts or resorting to the mouse to do formatting.
in #36 we merged the WIP for the image plugin to hallo. this is one of the tasks that remain to do:
the code starting here should be refactored to use the injected suggestions function:
https://github.com/bergie/hallo/blob/master/plugins/image.coffee#L148
this also involves porting this implementation of suggestions to create.
I know there is a dependency to jQuery UI too, but maybe this could be done to have a very minimalistic contentEditable editor.
Would be great!
in #36 we merged the WIP for the image plugin to hallo. this is one of the tasks that remain to do:
the drag and drop is somehow wobbly, there are layout issues with the blue areas and the dragged image is not always visible.
I'm creating this issue to mainly track the development of the Link plugin.
I see that on README it is stated that it's not currently working. Can you @bergie give some pointers where to go if I'm going to fix it? Is it just buggy or missing half of the implementation?
Thanks.
My last pull request has an issue with halloimage: 1) the hallodeactivated event closes the dialog, 2) which in turn calls my function overwriteToolbarFocus, 3) which calls focus on the editable, 4) which activates hallo again.
I fixed it with some spagetti like below, and it works. It comes with an instruction of how and when plugins should call these function ("on" and "off" on opening and closing the dialog, "silent" in the above scenario). But maybe a more elegant solution is possible? The easiest solution is to require dialogs to be modal, of course.
overwriteToolbarFocus: function(swtch) {
switch (swtch) {
case "on" :
this._overwriteToolbarFocus = true;
break;
case "off" :
this._overwriteToolbarFocus = false;
this.element.focus();
break;
case "silent" :
this._overwriteToolbarFocus = false;
break;
}
},
Hi. For some reason "ui-corner-left" and "ui-corner-right" classes are swapped in a buttonset in Chrome. For example among halloformat's buttons ("B", "I", "S" and "U"), "B" is supposed to have left round corner and "U" is supposed to have right round corner. Chrome got the other way around. Firefox displays this fine though, which is very strange.
Chrome version: 17.0
Add an option to make the toolbar appear at all times when an editable area is focused.
I imagine a color picker is quite essential to a lot of people.
I'm going to start working on this today as I need it in a project that I'm working on. If anyone has any thoughts on the best way to implement this, I would be glad to hear them.
On http://bergie.github.com/hallo/markdown.html, when adding a single letter, the Markdown window is updated correctly.
However, when deleting the same letter (thus restoring the original content), Markdown is not updated. This is not correct.
The cause of this lies in the event 'hallomodified', it only fires if (this.originalContent = this.getContents()). The expected behavior is not to compare the current content with the original content, but with the content since the previous 'hallomodified' event.
After selecting text and clicking somewhere to unselect, the toolbar does not disappear (tested with chrome, firefox, safari).
It disappears after you click for a second time.
Looks like the the mouseup event triggers before the text selection is updated.
After merging the pull request #24, the Hallo toolbar is now shown inconsistently:
Ping @rryter for getting this fixed.
When user has made a selection and chooses a different block-level formatting (from paragraph to a h2, for instance), this should affect only the selected area, not the whole paragraph.
The way to do this would be to split the current paragraph to its own block-level elements before and after the selection before the execCommand
call.
When user has no selection made, then the block-level formatting should affect the whole element.
Reported via Hacker News.
By default many browsers produce content like:
Foo <span style="font-weight: bold;">bar</span>
While what we usually want is:
Foo <strong>bar</strong>
Hallo should force browsers to produce the latter.
From Create issues:
With latest version if I have multiple editables in single page, each time I click on one I get new Hallo toolbar rendered on top of the previous one.
Hi,
I'm trying to implement a colorpicker into Hallo as it is essential to our app, and we love it so much that we don't really want to change it into anything else.
The only issue is that when a color is selected we run:
widget.options.editable.execute 'foreColor', '#' + color
But this loses the selection when the color is being selected on first click on canvas (dragging cursor over a canvas) and we're forced to reselect the text by hand. Is there any way to prevent the execute from removing the selection?
Thanks!
WebIntents would be a great way to connect some of the editor functionality with whatever social web services the user utilizes.
For example, insert link could choose the link based on a http://webintents.org/pick
intent looking for items of type text/uri-list
. This way the links could be coming from a CMS (if it registers such an intent), or from some social bookmarking service that the user uses.
While WebIntents are not yet supported by browsers, there is a JavaScript shim that we can use.
Aloha has a great feature in Repositories which allow plugins like image or link insertion to search the local system or external repositories (Delicious, Flickr, you name it) for resources user wants to insert.
Hallo should be able to do the same. One approach would be to use Backbone.js Models and Collections for this, as that would provide a very nice API for integrators, and allow two-way interaction (editor UI could even send stuff back to the repository).
How lightweight will Hallo be? In other words:
Where is the source for the markdown example? It doesn't appear to be in the git repository.
For formatting the hallo editor uses the browsers built in execCommand function. This works well for 'bold' but not at all for 'formatBlock' as it is not supported by IE. For other commands the browser behavior may differ wildly.
see: http://www.quirksmode.org/dom/execCommand.html
I guess the hallo editor will need a proper formatting engine. Maybe we could 'steal' one from http://www.github.com/xing/wysihtml5
Add an option to float the toolbar or position it relatively with an x and y offset.
https://github.com/liip/hallo/commit/afb3741aaf2cbd0b160a109f14a1712bc5c89976
A declarative, efficient, and flexible JavaScript library for building user interfaces.
๐ Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
An Open Source Machine Learning Framework for Everyone
The Web framework for perfectionists with deadlines.
A PHP framework for web artisans
Bring data to life with SVG, Canvas and HTML. ๐๐๐
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
Some thing interesting about web. New door for the world.
A server is a program made to process requests and deliver data to clients.
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
Some thing interesting about visualization, use data art
Some thing interesting about game, make everyone happy.
We are working to build community through open source technology. NB: members must have two-factor auth.
Open source projects and samples from Microsoft.
Google โค๏ธ Open Source for everyone.
Alibaba Open Source for everyone
Data-Driven Documents codes.
China tencent open source team.