@@ -3,15 +3,15 @@ Extensible = {
3
3
} ;
4
4
/**
5
5
* =================================================================================================
6
- *
6
+ *
7
7
* THIS FILE IS FOR *DEV* MODE ONLY, NOT FOR PRODUCTION USE!
8
- *
8
+ *
9
9
* =================================================================================================
10
- *
10
+ *
11
11
* This is intended as a development mode only convenience so that you can configure all include
12
12
* paths for all Extensible examples in one place. For production deployment you should configure
13
13
* your application with your own custom includes and/or Ext.Loader configuration directly.
14
- *
14
+ *
15
15
* =================================================================================================
16
16
*/
17
17
Extensible . Config = {
@@ -21,98 +21,101 @@ Extensible.Config = {
21
21
defaults : {
22
22
/**
23
23
* The mode to use for loading framework files. Valid values are:
24
- *
24
+ *
25
25
* - 'release': minified single file (e.g. ext-all.js)
26
26
* - 'debug': (default) non-minifed single file (e.g. ext-all-debug.js)
27
27
* - 'dynamic': uses Ext.Loader to load classes individually (e.g., ext.js). NOTE: this
28
28
* option does not work for IE, which will be defaulted to the 'debug' option.
29
- *
29
+ * - 'dynamic-extensible': Loads the Extensible framework dynically and the EXT JS framework from a
30
+ * non-minified single file. This loads much faster than the 'dynamic' mode. NOTE: This
31
+ * option does not work for IE, which will be defaulted to the 'debug' option.
32
+ *
30
33
* Typically the default of 'debug' is the best trade-off between code readability and
31
34
* load/execution speed. If you need to step into framework files frequently during
32
35
* debugging you might switch to 'dynamic' mode -- it is much slower during initial
33
36
* page load but generally provides a faster and easier debugging experience.
34
- *
37
+ *
35
38
* Note that for debug and release modes to reflect any code or CSS changes made to Extensible
36
39
* files you must rebuild the framework after each change using the scripts provided under
37
40
* the `/build` folder (requires Java). If you cannot build the framework and you've made any
38
41
* changes to Extensible files you should use dynamic mode to ensure that changes are reflected.
39
- *
42
+ *
40
43
* @config {String} mode
41
44
*/
42
- mode : 'debug ' ,
43
-
45
+ mode : 'dynamic-extensible ' ,
46
+
44
47
/**
45
48
* The root path to the Ext JS framework (defaults to loading 4.1.0 from the Sencha CDN via
46
49
* 'http://cdn.sencha.io/ext-4.1.0-gpl/'). Path should be absolute and should end with a '/'.
47
- *
50
+ *
48
51
* Note that the Sencha CDN does not always provide the most current version of Ext JS
49
52
* available (for example, support subscribers often have access to more up-to-date builds).
50
53
* If the version you need is not hosted you'll have to download it locally and update this
51
54
* path accordingly.
52
- *
55
+ *
53
56
* Alternate example values:
54
- *
57
+ *
55
58
* // Older Ext JS versions:
56
59
* http://cdn.sencha.io/ext-4.0.2/
57
- *
60
+ *
58
61
* // Direct to cachefly.net, e.g. if sencha.io is down:
59
62
* http://extjs.cachefly.net/ext-4.1.0-gpl/
60
- *
63
+ *
61
64
* // A custom absolute path:
62
65
* http://localhost/extjs/
63
66
* http://mydomain/extjs/4.0.2/
64
- *
67
+ *
65
68
* @config {String} extJsRoot
66
69
*/
67
70
extJsRoot : 'http://cdn.sencha.io/ext-4.2.0-gpl/' ,
68
-
71
+
69
72
/**
70
73
* The root path to the Extensible framework (defaults to the current url of this script file,
71
74
* 'Extensible-config.js', which is shipped in the root folder of Extensible). Path should
72
75
* be absolute and should end with a '/'.
73
- *
76
+ *
74
77
* Alternate example values:
75
- *
78
+ *
76
79
* // A custom absolute path:
77
80
* http://localhost/extensible/
78
81
* http://mydomain/extensible/1.0.1/
79
- *
82
+ *
80
83
* @config {String} extensibleRoot
81
84
*/
82
85
extensibleRoot : null , // initialized dynamically in getSdkPath()
83
-
86
+
84
87
/**
85
88
* True to allow the default browser behavior of caching the Extensible JS and CSS files
86
89
* after initial load (defaults to true), or false to append a unique cache-buster parameter
87
90
* to the url to enforce reloading Extensible files with each page refresh (useful if you are
88
91
* actively changing and debugging Extensible code). If true, the current version number of
89
92
* Extensible will still be used to force a reload with each new version of the framework, but
90
93
* after the initial load of each version the cached files will be used.
91
- *
94
+ *
92
95
* This option only applies when using `debug` or `dynamic` modes. In `release` mode the Extensible
93
96
* version number will be used to ensure that Extensible files are always cached after the initial
94
97
* load of each release and this option will be ignored. Note that when using `dynamic` mode you
95
98
* would additionally have to ensure that the Ext.Loader's `disableCaching` option is true in order
96
- * to add the cache buster parameter to each dynamically-loaded class.
97
- *
99
+ * to add the cache buster parameter to each dynamically-loaded class.
100
+ *
98
101
* Note that this option does not affect the caching of Ext JS files in any way. If you are
99
102
* using dynamic loading, the Ext Loader will govern caching, otherwise the default browser
100
103
* caching will be in effect.
101
- *
104
+ *
102
105
* @config {Boolean} cacheExtensible
103
106
*/
104
107
cacheExtensible : true ,
105
108
106
109
/**
107
110
* Language files to load for the Ext JS and Extensible frameworks. Valid values are ISO language codes of
108
111
* supported languages. See directory src/locale for a list of supported languages. Examples are:
109
- *
112
+ *
110
113
* - 'en'
111
114
* - 'en_GB'
112
115
* - 'de'
113
116
* - 'fr'
114
117
* - etc...
115
- *
118
+ *
116
119
* NOTE: This setting will NOT work for Ext versions < 4.1 due to how the locale files were written
117
120
* in 4.0.x. Because the 4.0.x locale files check for existence of classes by reference rather than
118
121
* by name, they do not play nicely when loaded asynchronously (Ext may load later, causing runtime
@@ -124,16 +127,16 @@ Extensible.Config = {
124
127
*/
125
128
language : null
126
129
} ,
127
-
130
+
128
131
/**
129
132
* Sets up all configurable properties and writes all includes to the document.
130
133
*/
131
134
init : function ( ) {
132
135
var me = this ,
133
136
config = window . ExtensibleDefaults || { } ;
134
-
137
+
135
138
me . isIE = / m s i e / . test ( navigator . userAgent . toLowerCase ( ) ) ;
136
-
139
+
137
140
me . mode = config . mode || me . defaults . mode ;
138
141
me . extJsRoot = config . extJsRoot || me . defaults . extJsRoot ;
139
142
me . extensibleRoot = config . extensibleRoot || me . defaults . extensibleRoot || me . getSdkPath ( ) ;
@@ -143,75 +146,70 @@ Extensible.Config = {
143
146
me . adjustPaths ( ) ;
144
147
me . writeIncludes ( ) ;
145
148
} ,
146
-
149
+
147
150
// private -- returns the current url to this script file, which is shipped in the SDK root folder
148
151
getSdkPath : function ( ) {
149
152
var scripts = document . getElementsByTagName ( 'script' ) ,
150
153
thisScriptSrc = scripts [ scripts . length - 1 ] . src ,
151
154
sdkPath = thisScriptSrc . substring ( 0 , thisScriptSrc . lastIndexOf ( '/' ) + 1 ) ;
152
-
155
+
153
156
return sdkPath ;
154
157
} ,
155
-
158
+
156
159
// private -- helper function for ease of deployment
157
160
adjustPaths : function ( ) {
158
161
if ( this . extensibleRoot . indexOf ( 'ext.ensible.com' ) > - 1 ) {
159
162
// If hosted at ext.ensible.com force non-debug release build includes
160
163
this . mode = 'release' ;
161
164
}
162
165
} ,
163
-
166
+
164
167
includeStylesheet : function ( filePath ) {
165
168
document . write ( '<link rel="stylesheet" type="text/css" href="' + filePath + '" />' ) ;
166
169
} ,
167
-
170
+
168
171
includeScript : function ( filePath ) {
169
172
document . write ( '<script type="text/javascript" src="' + filePath + '"></script>' ) ;
170
173
} ,
171
-
174
+
172
175
// private -- write out the CSS and script includes to the document
173
176
writeIncludes : function ( ) {
174
177
var me = this ,
175
- cacheBuster = '?_dc=' + ( me . cacheExtensible ? Extensible . version : ( + new Date ) ) ,
176
- suffixExt = '' ,
177
- suffixExtensible = '' ;
178
-
179
- switch ( me . mode ) {
180
- case 'debug' :
181
- suffixExt = '-all-debug' ;
182
- suffixExtensible = '-all-debug' ;
183
- break ;
184
-
185
- case 'release' :
186
- suffixExt = '-all' ;
187
- suffixExtensible = '-all'
188
- // For release we want to refresh the cache on first load, but allow caching
189
- // after that, so use the version number instead of a unique string
190
- cacheBuster = '?_dc=' + Extensible . version ;
191
- break ;
192
-
193
- default :
194
- // IE does not work in dynamic mode for the Extensible examples currently
195
- // based on how it (mis)handles loading of scripts when mixing includes
196
- // and in-page scripts. Make sure IE always uses the regular debug versions.
197
- if ( me . isIE ) {
198
- suffixExt = '-all-debug' ;
199
- suffixExtensible = '-all-debug' ;
200
- }
201
- else {
202
- suffixExt = '-debug' ;
203
- suffixExtensible = '-bootstrap' ;
204
- }
205
- }
206
-
178
+ cacheBuster = '?_dc=' + ( me . cacheExtensible ? Extensible . version : ( + new Date ) ) ;
179
+
180
+ // Include style sheets
207
181
me . includeStylesheet ( me . extJsRoot + 'resources/css/ext-all.css' ) ;
208
- me . includeStylesheet ( me . extensibleRoot + 'resources/css/extensible-all.css' + cacheBuster ) ;
182
+ if ( me . mode === 'release' ) {
183
+ me . includeStylesheet ( me . extensibleRoot + 'resources/css/extensible-all.css' + cacheBuster ) ;
184
+ } else {
185
+ me . includeStylesheet ( me . extensibleRoot + 'resources/css/calendar.css' + cacheBuster ) ;
186
+ me . includeStylesheet ( me . extensibleRoot + 'resources/css/calendar-colors.css' + cacheBuster ) ;
187
+ me . includeStylesheet ( me . extensibleRoot + 'resources/css/recurrence.css' + cacheBuster ) ;
188
+ }
209
189
me . includeStylesheet ( me . extensibleRoot + 'examples/examples.css?_dc=' + Extensible . version ) ;
210
-
211
- me . includeScript ( me . extJsRoot + 'ext' + suffixExt + '.js' ) ;
212
- me . includeScript ( me . extensibleRoot + 'lib/extensible' + suffixExtensible + '.js' + cacheBuster ) ;
190
+
191
+ // Include JS files
192
+ if ( me . mode === 'debug' || me . isIE ) {
193
+ // IE does not work in dynamic mode for the Extensible examples currently
194
+ // based on how it (mis)handles loading of scripts when mixing includes
195
+ // and in-page scripts. Make sure IE always uses the regular debug versions.
196
+ me . includeScript ( me . extJsRoot + 'ext-all-debug.js' ) ;
197
+ me . includeScript ( me . extensibleRoot + 'lib/extensible-all-debug.js' + cacheBuster ) ;
198
+ } else if ( me . mode === 'release' ) {
199
+ // For release we want to refresh the cache on first load, but allow caching
200
+ // after that, so use the version number instead of a unique string
201
+ cacheBuster = '?_dc=' + Extensible . version ;
202
+ me . includeScript ( me . extJsRoot + 'ext-all.js' ) ;
203
+ me . includeScript ( me . extensibleRoot + 'lib/extensible-all.js' + cacheBuster ) ;
204
+ } else {
205
+ if ( me . mode === 'dynamic-extensible' ) {
206
+ me . includeScript ( me . extJsRoot + 'ext-all-debug.js' ) ;
207
+ } else {
208
+ me . includeScript ( me . extJsRoot + 'ext-debug.js' ) ;
209
+ }
210
+ me . includeScript ( me . extensibleRoot + 'lib/extensible-bootstrap.js' + cacheBuster ) ;
211
+ }
213
212
me . includeScript ( me . extensibleRoot + 'examples/examples.js?_dc=' + Extensible . version ) ;
214
-
215
213
if ( me . language ) {
216
214
me . includeScript ( me . extJsRoot + 'locale/ext-lang-' + me . language + '.js' ) ;
217
215
me . includeScript ( me . extensibleRoot + 'src/locale/extensible-lang-' + me . language + '.js' + cacheBuster ) ;
0 commit comments