forked from cheef/jquery-ace
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjquery-ace.coffee
126 lines (97 loc) · 2.6 KB
/
jquery-ace.coffee
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
window.jQueryAce =
initialize: (element, options) ->
klass = switch true
when $(element).is('textarea')
jQueryAce.TextareaEditor
else
jQueryAce.BaseEditor
new klass element, options
defaults:
theme: null
lang: null
mode: null
width: null
height: null
version: '1.0.3'
require: ->
switch true
when typeof ace.require is 'function'
ace.require.apply null, arguments
when typeof window.require is 'function'
window.require.apply null, arguments
else
throw "Can't find 'require' function"
class jQueryAce.BaseEditor
constructor: (element, options = {}) ->
@element = $(element)
@options = $.extend {}, jQueryAce.defaults, options
create: ->
@editor = new jQueryAce.AceDecorator(ace.edit @element)
@update()
update: (options) ->
@options = $.extend {}, @options, options if options?
@editor.theme @options.theme if @options.theme?
lang = @options.lang || @options.mode
@editor.lang lang if lang?
destroy: ->
@element.data 'ace', null
@editor.destroy()
@element.empty()
class jQueryAce.TextareaEditor extends jQueryAce.BaseEditor
show: ->
@container?.show()
@element.hide()
hide: ->
@container?.hide()
@element.show()
create: ->
@container = @createAceContainer()
@editor = new jQueryAce.AceDecorator(ace.edit @container.get 0)
@update()
@editor.value @element.val()
@editor.ace.on 'change', (e) =>
@element.val @editor.value()
@show()
destroy: ->
super()
@hide()
@container.remove()
createAceContainer: ->
@buildAceContainer().insertAfter @element
buildAceContainer: ->
$('<div></div>').css
display: 'none'
position: 'relative'
width: @options.width || @element.width()
height: @options.height || @element.height()
class jQueryAce.AceDecorator
constructor: (@ace) ->
theme: (themeName) ->
@ace.setTheme "ace/theme/#{themeName}"
lang: (modeName) ->
klass = jQueryAce.require("ace/mode/#{modeName}").Mode
@session().setMode new klass
mode: (modeName) ->
@lang modeName
session: ->
@ace.getSession()
destroy: ->
@ace.destroy()
value: (text) ->
if text?
@ace.insert text
else
@ace.getValue()
(($) ->
$.ace = (element, options) ->
$(element).ace options
$.fn.ace = (options) ->
@each ->
editor = $(@).data 'ace'
if editor?
editor.update options
else
editor = jQueryAce.initialize @, options
editor.create()
$(@).data 'ace', editor
)(jQuery)