]> scripts.mit.edu Git - autoinstallsdev/mediawiki.git/blobdiff - vendor/oojs/oojs-ui/demos/pages/dialogs.js
MediaWiki 1.30.2
[autoinstallsdev/mediawiki.git] / vendor / oojs / oojs-ui / demos / pages / dialogs.js
diff --git a/vendor/oojs/oojs-ui/demos/pages/dialogs.js b/vendor/oojs/oojs-ui/demos/pages/dialogs.js
new file mode 100644 (file)
index 0000000..1b11cb2
--- /dev/null
@@ -0,0 +1,333 @@
+Demo.static.pages.dialogs = function ( demo ) {
+       var i, j, name, openButton, fieldset, examples, DialogClass, config,
+               $demo = demo.$element,
+               $fieldsets = $( [] ),
+               windows = {},
+               windowManager = new OO.ui.WindowManager();
+
+       config = [
+               {
+                       name: 'Convenience functions',
+                       examples: [
+                               {
+                                       name: 'Quick alert',
+                                       method: 'alert',
+                                       param: 'Alert message.'
+                               },
+                               {
+                                       name: 'Larger alert',
+                                       method: 'alert',
+                                       param: 'Alert message.',
+                                       data: { size: 'larger' }
+                               },
+                               {
+                                       name: 'Quick confirm',
+                                       method: 'confirm',
+                                       param: 'Confirmation message?'
+                               },
+                               {
+                                       name: 'Quick prompt',
+                                       method: 'prompt',
+                                       param: 'Text prompt:'
+                               }
+                       ]
+               },
+               {
+                       name: 'Dialog interface',
+                       examples: [
+                               {
+                                       name: 'Simple dialog (small)',
+                                       config: {
+                                               size: 'small'
+                                       }
+                               },
+                               {
+                                       name: 'Simple dialog (medium)',
+                                       config: {
+                                               size: 'medium'
+                                       }
+                               },
+                               {
+                                       name: 'Simple dialog (large)',
+                                       config: {
+                                               size: 'large'
+                                       }
+                               },
+                               {
+                                       name: 'Simple dialog (larger)',
+                                       config: {
+                                               size: 'larger'
+                                       }
+                               },
+                               {
+                                       name: 'Simple dialog (full)',
+                                       config: {
+                                               size: 'full'
+                                       }
+                               },
+                               {
+                                       name: 'Simple dialog (delayed ready process)',
+                                       dialogClass: Demo.DelayedReadyProcessDialog,
+                                       config: {
+                                               size: 'large'
+                                       }
+                               },
+                               {
+                                       name: 'Simple dialog (failed ready process)',
+                                       dialogClass: Demo.FailedReadyProcessDialog,
+                                       config: {
+                                               size: 'large'
+                                       }
+                               },
+                               {
+                                       name: 'Simple dialog (failed setup process)',
+                                       dialogClass: Demo.FailedSetupProcessDialog,
+                                       config: {
+                                               size: 'large'
+                                       }
+                               },
+                               {
+                                       name: 'Process dialog (medium)',
+                                       dialogClass: Demo.ProcessDialog,
+                                       config: {
+                                               size: 'medium'
+                                       }
+                               },
+                               {
+                                       name: 'Process dialog (medium, long title)',
+                                       dialogClass: Demo.ProcessDialog,
+                                       config: {
+                                               size: 'medium'
+                                       },
+                                       data: {
+                                               title: 'Sample dialog with very long title that does not fit'
+                                       }
+                               },
+                               {
+                                       name: 'Process dialog (medium, long)',
+                                       dialogClass: Demo.LongProcessDialog,
+                                       config: {
+                                               size: 'medium'
+                                       }
+                               },
+                               {
+                                       name: 'Process dialog (full)',
+                                       dialogClass: Demo.ProcessDialog,
+                                       config: {
+                                               size: 'full'
+                                       }
+                               },
+                               {
+                                       name: 'Broken dialog (error handling)',
+                                       dialogClass: Demo.BrokenDialog,
+                                       config: {
+                                               size: 'medium'
+                                       }
+                               },
+                               {
+                                       name: 'Message dialog (generic)',
+                                       dialogClass: OO.ui.MessageDialog,
+                                       data: {
+                                               title: 'Continue?',
+                                               message: 'It may be risky'
+                                       }
+                               },
+                               {
+                                       name: 'Message dialog (lengthy)',
+                                       dialogClass: OO.ui.MessageDialog,
+                                       data: {
+                                               title: 'Continue?',
+                                               message: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque quis laoreet elit. Nam eu velit ullamcorper, volutpat elit sed, viverra massa. Aenean congue aliquam lorem, et laoreet risus condimentum vel. Praesent nec imperdiet mauris. Nunc eros magna, iaculis sit amet ante id, dapibus tristique lorem. Praesent in feugiat lorem, sit amet porttitor eros. Donec sapien turpis, pretium eget ligula id, scelerisque tincidunt diam. Pellentesque a venenatis tortor, at luctus nisl. Quisque vel urna a enim mattis rutrum. Morbi eget consequat nisl. Nam tristique molestie diam ac consequat. Nam varius adipiscing mattis. Praesent sodales volutpat nulla lobortis iaculis. Quisque vel odio eget diam posuere imperdiet. Fusce et iaculis odio. Donec in nibh ut dui accumsan vehicula quis et massa.'
+                                       }
+                               },
+                               {
+                                       name: 'Message dialog (1 action)',
+                                       dialogClass: OO.ui.MessageDialog,
+                                       data: {
+                                               title: 'Storage limit reached',
+                                               message: 'You are out of disk space',
+                                               actions: [
+                                                       {
+                                                               action: 'accept',
+                                                               label: 'Dismiss',
+                                                               flags: 'primary'
+                                                       }
+                                               ]
+                                       }
+                               },
+                               {
+                                       name: 'Message dialog (2 actions)',
+                                       dialogClass: OO.ui.MessageDialog,
+                                       data: {
+                                               title: 'Cannot save data',
+                                               message: 'The server is not responding',
+                                               actions: [
+                                                       {
+                                                               action: 'reject',
+                                                               label: 'Cancel',
+                                                               flags: [ 'safe', 'back' ]
+                                                       },
+                                                       {
+                                                               action: 'repeat',
+                                                               label: 'Try again',
+                                                               flags: [ 'primary', 'constructive' ]
+                                                       }
+                                               ]
+                                       }
+                               },
+                               {
+                                       name: 'Message dialog (3 actions)',
+                                       dialogClass: OO.ui.MessageDialog,
+                                       data: {
+                                               title: 'Delete file?',
+                                               message: 'The file will be irreversably obliterated. Proceed with caution.',
+                                               actions: [
+                                                       { action: 'reject', label: 'Cancel', flags: [ 'safe', 'back' ] },
+                                                       { action: 'reject', label: 'Move file to trash' },
+                                                       {
+                                                               action: 'accept',
+                                                               label: 'Obliterate',
+                                                               flags: [ 'primary', 'destructive' ]
+                                                       }
+                                               ]
+                                       }
+                               }
+                       ]
+               },
+               {
+                       name: 'Elements best used inside dialogs',
+                       examples: [
+                               {
+                                       name: 'Search widget dialog (medium)',
+                                       dialogClass: Demo.SearchWidgetDialog,
+                                       config: {
+                                               size: 'medium'
+                                       }
+                               },
+                               {
+                                       name: 'Booklet dialog',
+                                       dialogClass: Demo.BookletDialog,
+                                       config: {
+                                               size: 'medium'
+                                       }
+                               },
+                               {
+                                       name: 'Outlined booklet dialog (aside navigation)',
+                                       dialogClass: Demo.OutlinedBookletDialog,
+                                       config: {
+                                               size: 'medium'
+                                       }
+                               },
+                               {
+                                       name: 'Continuous outlined booklet dialog (aside navigation)',
+                                       dialogClass: Demo.ContinuousOutlinedBookletDialog,
+                                       config: {
+                                               size: 'medium'
+                                       }
+                               },
+                               {
+                                       name: 'Indexed dialog (tab navigation)',
+                                       dialogClass: Demo.IndexedDialog,
+                                       config: {
+                                               size: 'medium'
+                                       }
+                               },
+                               {
+                                       name: 'Menu dialog',
+                                       dialogClass: Demo.MenuDialog,
+                                       config: {
+                                               size: 'medium'
+                                       }
+                               }
+                       ]
+               },
+               {
+                       name: 'Low-level test cases',
+                       examples: [
+                               {
+                                       name: 'FloatableElement test',
+                                       dialogClass: Demo.FloatableTest,
+                                       config: {
+                                               size: 'medium'
+                                       }
+                               },
+                               {
+                                       name: 'Dialog with dropdowns ($overlay test)',
+                                       dialogClass: Demo.DialogWithDropdowns,
+                                       config: {
+                                               size: 'large'
+                                       }
+                               },
+                               {
+                                       name: 'PopupButtonWidget test',
+                                       dialogClass: Demo.PopupButtonWidgetTest,
+                                       config: {
+                                               size: 'large'
+                                       }
+                               },
+                               {
+                                       name: 'Dialog with popup and dropdown (ClippableElement test)',
+                                       dialogClass: Demo.DialogWithPopupAndDropdown,
+                                       config: {
+                                               size: 'large'
+                                       }
+                               }
+                       ]
+               }
+       ];
+
+       function openDialog( name, data ) {
+               windowManager.openWindow( name, data );
+       }
+
+       for ( j = 0; j < config.length; j++ ) {
+               fieldset = new OO.ui.FieldsetLayout( { label: config[ j ].name } );
+               examples = config[ j ].examples;
+               $fieldsets = $fieldsets.add( fieldset.$element );
+
+               for ( i = 0; i < examples.length; i++ ) {
+                       openButton = new OO.ui.ButtonWidget( {
+                               framed: false,
+                               icon: 'window',
+                               label: $( '<span dir="ltr"></span>' ).text( examples[ i ].name )
+                       } );
+
+                       if ( examples[ i ].method ) {
+                               openButton.on(
+                                       'click', OO.ui.bind(
+                                               OO.ui,
+                                               examples[ i ].method,
+                                               examples[ i ].param,
+                                               examples[ i ].data
+                                       )
+                               );
+                       } else {
+                               name = 'window_' + j + '_' + i;
+                               DialogClass = examples[ i ].dialogClass || Demo.SimpleDialog;
+                               windows[ name ] = new DialogClass( examples[ i ].config );
+                               openButton.on(
+                                       'click', OO.ui.bind( openDialog, this, name, examples[ i ].data )
+                               );
+                       }
+
+                       fieldset.addItems( [ new OO.ui.FieldLayout( openButton, { align: 'inline' } ) ] );
+               }
+       }
+       windowManager.addWindows( windows );
+
+       $demo.append(
+               new OO.ui.PanelLayout( {
+                       expanded: false,
+                       framed: true
+               } ).$element
+                       .addClass( 'demo-container' )
+                       .attr( 'role', 'main' )
+                       .append( $fieldsets ),
+               windowManager.$element
+       );
+
+       demo.once( 'destroy', function () {
+               windowManager.destroy();
+               OO.ui.getWindowManager().closeWindow( OO.ui.getWindowManager().getCurrentWindow() );
+       } );
+};