Merge "Replace Linker::link() with LinkRenderer in includes directory"
[lhc/web/wiklou.git] / resources / src / mediawiki / mediawiki.Upload.Dialog.js
1 ( function ( $, mw ) {
2
3 /**
4 * mw.Upload.Dialog controls a {@link mw.Upload.BookletLayout BookletLayout}.
5 *
6 * ## Usage
7 *
8 * To use, setup a {@link OO.ui.WindowManager window manager} like for normal
9 * dialogs:
10 *
11 * var uploadDialog = new mw.Upload.Dialog();
12 * var windowManager = new OO.ui.WindowManager();
13 * $( 'body' ).append( windowManager.$element );
14 * windowManager.addWindows( [ uploadDialog ] );
15 * windowManager.openWindow( uploadDialog );
16 *
17 * The dialog's closing promise can be used to get details of the upload.
18 *
19 * If you want to use a different OO.ui.BookletLayout, for example the
20 * mw.ForeignStructuredUpload.BookletLayout, like in the case of of the upload
21 * interface in VisualEditor, you can pass it in the {@link #cfg-bookletClass}:
22 *
23 * var uploadDialog = new mw.Upload.Dialog( {
24 * bookletClass: mw.ForeignStructuredUpload.BookletLayout
25 * } );
26 *
27 *
28 * @class mw.Upload.Dialog
29 * @uses mw.Upload
30 * @uses mw.Upload.BookletLayout
31 * @extends OO.ui.ProcessDialog
32 *
33 * @constructor
34 * @param {Object} [config] Configuration options
35 * @cfg {Function} [bookletClass=mw.Upload.BookletLayout] Booklet class to be
36 * used for the steps
37 * @cfg {Object} [booklet] Booklet constructor configuration
38 */
39 mw.Upload.Dialog = function ( config ) {
40 // Config initialization
41 config = $.extend( {
42 bookletClass: mw.Upload.BookletLayout
43 }, config );
44
45 // Parent constructor
46 mw.Upload.Dialog.parent.call( this, config );
47
48 // Initialize
49 this.bookletClass = config.bookletClass;
50 this.bookletConfig = config.booklet;
51 };
52
53 /* Setup */
54
55 OO.inheritClass( mw.Upload.Dialog, OO.ui.ProcessDialog );
56
57 /* Static Properties */
58
59 /**
60 * @inheritdoc
61 * @property title
62 */
63 mw.Upload.Dialog.static.title = mw.msg( 'upload-dialog-title' );
64
65 /**
66 * @inheritdoc
67 * @property actions
68 */
69 mw.Upload.Dialog.static.actions = [
70 {
71 flags: 'safe',
72 action: 'cancel',
73 label: mw.msg( 'upload-dialog-button-cancel' ),
74 modes: [ 'upload', 'insert' ]
75 },
76 {
77 flags: 'safe',
78 action: 'cancelupload',
79 label: mw.msg( 'upload-dialog-button-back' ),
80 modes: [ 'info' ]
81 },
82 {
83 flags: [ 'primary', 'progressive' ],
84 label: mw.msg( 'upload-dialog-button-done' ),
85 action: 'insert',
86 modes: 'insert'
87 },
88 {
89 flags: [ 'primary', 'progressive' ],
90 label: mw.msg( 'upload-dialog-button-save' ),
91 action: 'save',
92 modes: 'info'
93 },
94 {
95 flags: [ 'primary', 'progressive' ],
96 label: mw.msg( 'upload-dialog-button-upload' ),
97 action: 'upload',
98 modes: 'upload'
99 }
100 ];
101
102 /* Methods */
103
104 /**
105 * @inheritdoc
106 */
107 mw.Upload.Dialog.prototype.initialize = function () {
108 // Parent method
109 mw.Upload.Dialog.parent.prototype.initialize.call( this );
110
111 this.uploadBooklet = this.createUploadBooklet();
112 this.uploadBooklet.connect( this, {
113 set: 'onUploadBookletSet',
114 uploadValid: 'onUploadValid',
115 infoValid: 'onInfoValid'
116 } );
117
118 this.$body.append( this.uploadBooklet.$element );
119 };
120
121 /**
122 * Create an upload booklet
123 *
124 * @protected
125 * @return {mw.Upload.BookletLayout} An upload booklet
126 */
127 mw.Upload.Dialog.prototype.createUploadBooklet = function () {
128 // eslint-disable-next-line new-cap
129 return new this.bookletClass( $.extend( {
130 $overlay: this.$overlay
131 }, this.bookletConfig ) );
132 };
133
134 /**
135 * @inheritdoc
136 */
137 mw.Upload.Dialog.prototype.getBodyHeight = function () {
138 return 600;
139 };
140
141 /**
142 * Handle panelNameSet events from the upload booklet
143 *
144 * @protected
145 * @param {OO.ui.PageLayout} page Current page
146 */
147 mw.Upload.Dialog.prototype.onUploadBookletSet = function ( page ) {
148 this.actions.setMode( page.getName() );
149 this.actions.setAbilities( { upload: false, save: false } );
150 };
151
152 /**
153 * Handle uploadValid events
154 *
155 * {@link OO.ui.ActionSet#setAbilities Sets abilities}
156 * for the dialog accordingly.
157 *
158 * @protected
159 * @param {boolean} isValid The panel is complete and valid
160 */
161 mw.Upload.Dialog.prototype.onUploadValid = function ( isValid ) {
162 this.actions.setAbilities( { upload: isValid } );
163 };
164
165 /**
166 * Handle infoValid events
167 *
168 * {@link OO.ui.ActionSet#setAbilities Sets abilities}
169 * for the dialog accordingly.
170 *
171 * @protected
172 * @param {boolean} isValid The panel is complete and valid
173 */
174 mw.Upload.Dialog.prototype.onInfoValid = function ( isValid ) {
175 this.actions.setAbilities( { save: isValid } );
176 };
177
178 /**
179 * @inheritdoc
180 */
181 mw.Upload.Dialog.prototype.getSetupProcess = function ( data ) {
182 return mw.Upload.Dialog.parent.prototype.getSetupProcess.call( this, data )
183 .next( function () {
184 return this.uploadBooklet.initialize();
185 }, this );
186 };
187
188 /**
189 * @inheritdoc
190 */
191 mw.Upload.Dialog.prototype.getActionProcess = function ( action ) {
192 var dialog = this;
193
194 if ( action === 'upload' ) {
195 return new OO.ui.Process( this.uploadBooklet.uploadFile() );
196 }
197 if ( action === 'save' ) {
198 return new OO.ui.Process( this.uploadBooklet.saveFile() );
199 }
200 if ( action === 'insert' ) {
201 return new OO.ui.Process( function () {
202 dialog.close( dialog.upload );
203 } );
204 }
205 if ( action === 'cancel' ) {
206 return new OO.ui.Process( this.close() );
207 }
208 if ( action === 'cancelupload' ) {
209 return new OO.ui.Process( this.uploadBooklet.initialize() );
210 }
211
212 return mw.Upload.Dialog.parent.prototype.getActionProcess.call( this, action );
213 };
214
215 /**
216 * @inheritdoc
217 */
218 mw.Upload.Dialog.prototype.getTeardownProcess = function ( data ) {
219 return mw.Upload.Dialog.parent.prototype.getTeardownProcess.call( this, data )
220 .next( function () {
221 this.uploadBooklet.clear();
222 }, this );
223 };
224 }( jQuery, mediaWiki ) );