mirror of
				https://github.com/zulip/zulip.git
				synced 2025-11-04 05:53:43 +00:00 
			
		
		
		
	`replace_syntax` will replace text inside of a compose textbox. Also, add tests to the `compose_ui` Node tests for this function.
		
			
				
	
	
		
			72 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			72 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
var compose_ui = (function () {
 | 
						|
 | 
						|
var exports = {};
 | 
						|
 | 
						|
exports.autosize_textarea = function () {
 | 
						|
    $("#compose-textarea").trigger("autosize.resize");
 | 
						|
};
 | 
						|
 | 
						|
exports.smart_insert = function (textarea, syntax) {
 | 
						|
    function is_space(c) {
 | 
						|
        return c === ' ' || c === '\t' || c === '\n';
 | 
						|
    }
 | 
						|
 | 
						|
    var pos = textarea.caret();
 | 
						|
    var before_str = textarea.val().slice(0, pos);
 | 
						|
    var after_str = textarea.val().slice(pos);
 | 
						|
 | 
						|
    if (pos > 0) {
 | 
						|
        if (!is_space(before_str.slice(-1))) {
 | 
						|
            syntax = ' ' + syntax;
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    if (!(after_str.length > 0 && is_space(after_str[0]))) {
 | 
						|
        syntax += ' ';
 | 
						|
    }
 | 
						|
 | 
						|
    textarea.focus();
 | 
						|
 | 
						|
    // We prefer to use insertText, which supports things like undo better
 | 
						|
    // for rich-text editing features like inserting links.  But we fall
 | 
						|
    // back to textarea.caret if the browser doesn't support insertText.
 | 
						|
    if (!document.execCommand("insertText", false, syntax)) {
 | 
						|
        textarea.caret(syntax);
 | 
						|
    }
 | 
						|
 | 
						|
    // This should just call exports.autosize_textarea, but it's a bit
 | 
						|
    // annoying for the unit tests, so we don't do that.
 | 
						|
    textarea.trigger("autosize.resize");
 | 
						|
};
 | 
						|
 | 
						|
exports.insert_syntax_and_focus = function (syntax, textarea) {
 | 
						|
    // Generic helper for inserting syntax into the main compose box
 | 
						|
    // where the cursor was and focusing the area.  Mostly a thin
 | 
						|
    // wrapper around smart_insert.
 | 
						|
    if (textarea === undefined) {
 | 
						|
        textarea = $('#compose-textarea');
 | 
						|
    }
 | 
						|
    exports.smart_insert(textarea, syntax);
 | 
						|
};
 | 
						|
 | 
						|
exports.replace_syntax = function (old_syntax, new_syntax, textarea) {
 | 
						|
    // Replaces `old_syntax` with `new_syntax` text in the compose box. Due to
 | 
						|
    // the way that JavaScript handles string replacements, if `old_syntax` is
 | 
						|
    // a string it will only replace the first instance. If `old_syntax` is
 | 
						|
    // a RegExp with a global flag, it will replace all instances.
 | 
						|
 | 
						|
    if (textarea === undefined) {
 | 
						|
        textarea = $('#compose-textarea');
 | 
						|
    }
 | 
						|
 | 
						|
    textarea.val(textarea.val().replace(old_syntax, new_syntax));
 | 
						|
};
 | 
						|
 | 
						|
return exports;
 | 
						|
 | 
						|
}());
 | 
						|
if (typeof module !== 'undefined') {
 | 
						|
    module.exports = compose_ui;
 | 
						|
}
 | 
						|
window.compose_ui = compose_ui;
 |