Server : Apache System : Linux indy02.toastserver.com 3.10.0-962.3.2.lve1.5.85.el7.x86_64 #1 SMP Thu Apr 18 15:18:36 UTC 2024 x86_64 User : palandch ( 1163) PHP Version : 7.1.33 Disable Function : NONE Directory : /home/palandch/www/manager/assets/modext/widgets/element/ |
/** * Loads the TV panel * * @class MODx.panel.TV * @extends MODx.FormPanel * @param {Object} config An object of configuration properties * @xtype modx-panel-tv */ MODx.panel.TV = function(config) { config = config || {}; Ext.applyIf(config,{ url: MODx.config.connectors_url+'element/tv.php' ,baseParams: {} ,id: 'modx-panel-tv' ,cls: 'container form-with-labels' ,class_key: 'modTemplateVar' ,tv: '' ,bodyStyle: '' ,items: [{ html: '<h2>'+_('tv_new')+'</h2>' ,id: 'modx-tv-header' ,itemId: 'header' ,cls: 'modx-page-header' ,border: false },MODx.getPageStructure([{ title: _('general_information') ,defaults: {border: false ,msgTarget: 'side', layout: 'form'} ,layout: 'form' ,id: 'modx-tv-form' ,itemId: 'form-tv' ,labelWidth: 150 ,forceLayout: true ,items: [{ html: '<p>'+_('tv_msg')+'</p>' ,bodyCssClass: 'panel-desc' ,id: 'modx-tv-msg' },{ layout: 'column' ,border: false ,defaults: { layout: 'form' ,labelAlign: 'top' ,anchor: '100%' ,border: false ,cls:'main-wrapper' ,labelSeparator: '' } ,items: [{ columnWidth: .6 ,items: [{ xtype: 'hidden' ,name: 'id' ,id: 'modx-tv-id' ,value: config.record.id || MODx.request.id },{ xtype: 'hidden' ,name: 'props' ,id: 'modx-tv-props' ,value: config.record.props || null },{ xtype: 'textfield' ,fieldLabel: _('name')+'<span class="required">*</span>' ,description: MODx.expandHelp ? '' : _('tv_desc_name') ,name: 'name' ,id: 'modx-tv-name' ,anchor: '100%' ,maxLength: 100 ,enableKeyEvents: true ,allowBlank: false ,value: config.record.name ,listeners: { 'keyup': {scope:this,fn:function(f,e) { Ext.getCmp('modx-tv-header').getEl().update('<h2>'+_('tv')+': '+f.getValue()+'</h2>'); }} } },{ xtype: MODx.expandHelp ? 'label' : 'hidden' ,forId: 'modx-tv-name' ,html: _('tv_desc_name') ,cls: 'desc-under' },{ xtype: 'textfield' ,fieldLabel: _('tv_caption') ,description: MODx.expandHelp ? '' : _('tv_desc_caption') ,name: 'caption' ,id: 'modx-tv-caption' ,anchor: '100%' ,value: config.record.caption },{ xtype: MODx.expandHelp ? 'label' : 'hidden' ,forId: 'modx-tv-caption' ,html: _('tv_desc_caption') ,cls: 'desc-under' },{ xtype: 'textarea' ,fieldLabel: _('description') ,description: MODx.expandHelp ? '' : _('tv_desc_description') ,name: 'description' ,id: 'modx-tv-description' ,anchor: '100%' ,maxLength: 255 ,value: config.record.description || '' },{ xtype: MODx.expandHelp ? 'label' : 'hidden' ,forId: 'modx-tv-description' ,html: _('tv_desc_description') ,cls: 'desc-under' },{ xtype: 'modx-combo-browser' ,browserEl: 'modx-browser' ,fieldLabel: _('static_file') ,description: MODx.expandHelp ? '' : _('static_file_msg') ,name: 'static_file' ,hideFiles: true ,openTo: config.record.openTo || '' ,id: 'modx-tv-static-file' ,anchor: '100%' ,maxLength: 255 ,value: config.record.static_file || '' ,hidden: !config.record['static'] ,hideMode: 'offsets' },{ xtype: MODx.expandHelp ? 'label' : 'hidden' ,forId: 'modx-tv-static-file' ,id: 'modx-tv-static-file-help' ,html: _('static_file_msg') ,cls: 'desc-under' ,hidden: !config.record['static'] ,hideMode: 'offsets' },{ html: MODx.onTVFormRender ,border: false }] },{ columnWidth: .4 ,items: [{ xtype: 'modx-combo-category' ,fieldLabel: _('category') ,name: 'category' ,id: 'modx-tv-category' ,anchor: '100%' ,value: config.record.category || 0 },{ xtype: MODx.expandHelp ? 'label' : 'hidden' ,forId: 'modx-tv-category' ,html: _('tv_desc_category') ,cls: 'desc-under' },{ xtype: 'numberfield' ,fieldLabel: _('tv_rank') ,name: 'rank' ,id: 'modx-tv-rank' ,width: 50 ,maxLength: 4 ,allowNegative: false ,allowBlank: false ,value: config.record.rank || 0 },{ xtype: 'xcheckbox' ,boxLabel: _('tv_lock') ,description: _('tv_lock_msg') ,name: 'locked' ,id: 'modx-tv-locked' ,inputValue: 1 ,checked: config.record.locked || false },{ xtype: 'xcheckbox' ,boxLabel: _('clear_cache_on_save') ,description: _('clear_cache_on_save_msg') ,hideLabel: true ,name: 'clearCache' ,id: 'modx-tv-clear-cache' ,inputValue: 1 ,checked: Ext.isDefined(config.record.clearCache) || true },{border: false, html: '<br style="line-height: 25px;"/>'},{ xtype: 'xcheckbox' ,hideLabel: true ,boxLabel: _('is_static') ,description: MODx.expandHelp ? '' : _('is_static_msg') ,name: 'static' ,id: 'modx-tv-static' ,inputValue: 1 ,checked: config.record['static'] || false },{ xtype: MODx.expandHelp ? 'label' : 'hidden' ,forId: 'modx-tv-static' ,id: 'modx-tv-static-help' ,html: _('is_static_msg') ,cls: 'desc-under' },{ xtype: 'modx-combo-source' ,fieldLabel: _('static_source') ,description: MODx.expandHelp ? '' : _('static_source_msg') ,name: 'source' ,id: 'modx-tv-static-source' ,anchor: '100%' ,maxLength: 255 ,value: config.record.source != null ? config.record.source : MODx.config.default_media_source ,hidden: !config.record['static'] ,hideMode: 'offsets' ,baseParams: { action: 'getList' ,showNone: true ,streamsOnly: true } },{ xtype: MODx.expandHelp ? 'label' : 'hidden' ,forId: 'modx-tv-static-source' ,id: 'modx-tv-static-source-help' ,html: _('static_source_msg') ,cls: 'desc-under' ,hidden: !config.record['static'] ,hideMode: 'offsets' }] }] }] },{ xtype: 'modx-panel-element-properties' ,itemId: 'panel-properties' ,elementPanel: 'modx-panel-tv' ,elementId: config.tv ,elementType: 'modTemplateVar' ,record: config.record },{ xtype: 'modx-panel-tv-input-properties' ,record: config.record },{ xtype: 'modx-panel-tv-output-properties' ,record: config.record },{ title: _('tv_tmpl_access') ,itemId: 'form-template' ,hideMode: 'offsets' ,defaults: {autoHeight: true} ,layout: 'form' ,items: [{ html: '<p>'+_('tv_tmpl_access_msg')+'</p>' ,bodyCssClass: 'panel-desc' ,border: false },{ xtype: 'modx-grid-tv-template' ,itemId: 'grid-template' ,cls:'main-wrapper' ,tv: config.tv ,preventRender: true ,anchor: '100%' ,listeners: { 'rowclick': {fn:this.markDirty,scope:this} ,'afteredit': {fn:this.markDirty,scope:this} ,'afterRemoveRow': {fn:this.markDirty,scope:this} } }] },{ title: _('access_permissions') ,id: 'modx-tv-access-form' ,itemId: 'form-access' ,forceLayout: true ,hideMode: 'offsets' ,defaults: {autoHeight: true} ,layout: 'form' ,items: [{ html: '<p>'+_('tv_access_msg')+'</p>' ,bodyCssClass: 'panel-desc' ,id: 'modx-tv-access-msg' ,border: false },{ xtype: 'modx-grid-tv-security' ,itemId: 'grid-access' ,cls:'main-wrapper' ,tv: config.tv ,preventRender: true ,anchor: '100%' ,listeners: { 'rowclick': {fn:this.markDirty,scope:this} ,'afteredit': {fn:this.markDirty,scope:this} ,'afterRemoveRow': {fn:this.markDirty,scope:this} } }] },{ title: _('sources') ,id: 'modx-tv-sources-form' ,itemId: 'form-sources' ,defaults: {autoHeight: true} ,layout: 'form' ,hideMode: 'offsets' ,items: [{ html: '<p>'+_('tv_sources.intro_msg')+'</p>' ,bodyCssClass: 'panel-desc' ,id: 'modx-tv-sources-msg' ,border: false },{ xtype: 'modx-grid-element-sources' ,itemId: 'grid-sources' ,cls:'main-wrapper' ,id: 'modx-grid-element-sources' ,tv: config.tv ,preventRender: true ,listeners: { 'rowclick': {fn:this.markDirty,scope:this} ,'afteredit': {fn:this.markDirty,scope:this} ,'afterRemoveRow': {fn:this.markDirty,scope:this} } }] }],{ id: 'modx-tv-tabs' ,forceLayout: true ,deferredRender: false ,stateful: true ,stateId: 'modx-tv-tabpanel-'+config.tv ,stateEvents: ['tabchange'] ,hideMode: 'offsets' ,anchor: '100%' ,getState:function() { return {activeTab:this.items.indexOf(this.getActiveTab())}; } })] ,useLoadingMask: true ,listeners: { 'setup': {fn:this.setup,scope:this} ,'success': {fn:this.success,scope:this} ,'beforeSubmit': {fn:this.beforeSubmit,scope:this} } }); MODx.panel.TV.superclass.constructor.call(this,config); var isStatic = Ext.getCmp('modx-tv-static'); if (isStatic) { isStatic.on('check',this.toggleStaticFile); } }; Ext.extend(MODx.panel.TV,MODx.FormPanel,{ initialized: false ,setup: function() { if (this.initialized) { this.clearDirty(); return true; } this.getForm().setValues(this.config.record); if (!Ext.isEmpty(this.config.record.name)) { Ext.getCmp('modx-tv-header').getEl().update('<h2>'+_('tv')+': '+this.config.record.name+'</h2>'); } var d; if (!Ext.isEmpty(this.config.record.properties)) { d = this.config.record.properties; var g = Ext.getCmp('modx-grid-element-properties'); if (g) { g.defaultProperties = d; g.getStore().loadData(d); } } if (!Ext.isEmpty(this.config.record.sources) && !this.initialized) { Ext.getCmp('modx-grid-element-sources').getStore().loadData(this.config.record.sources); } Ext.getCmp('modx-panel-tv-output-properties').showOutputProperties(Ext.getCmp('modx-tv-display')); Ext.getCmp('modx-panel-tv-input-properties').showInputProperties(Ext.getCmp('modx-tv-type')); this.fireEvent('ready',this.config.record); if (MODx.onLoadEditor) {MODx.onLoadEditor(this);} this.clearDirty(); this.initialized = true; MODx.fireEvent('ready'); return true; } ,beforeSubmit: function(o) { var g = Ext.getCmp('modx-grid-tv-template'); var rg = Ext.getCmp('modx-grid-tv-security'); var sg = Ext.getCmp('modx-grid-element-sources'); Ext.apply(o.form.baseParams,{ templates: g.encodeModified() ,resource_groups: rg.encodeModified() ,sources: sg.encode() ,propdata: Ext.getCmp('modx-grid-element-properties').encode() }); this.cleanupEditor(); return this.fireEvent('save',{ values: this.getForm().getValues() ,stay: MODx.config.stay }); } ,success: function(r) { Ext.getCmp('modx-grid-tv-template').getStore().commitChanges(); Ext.getCmp('modx-grid-tv-security').getStore().commitChanges(); Ext.getCmp('modx-grid-element-sources').getStore().commitChanges(); if (MODx.request.id) Ext.getCmp('modx-grid-element-properties').save(); this.getForm().setValues(r.result.object); var t = Ext.getCmp('modx-element-tree'); if (t) { var c = Ext.getCmp('modx-tv-category').getValue(); var u = c != '' && c != null && c != 0 ? 'n_tv_category_'+c : 'n_type_tv'; var node = t.getNodeById('n_tv_element_' + Ext.getCmp('modx-tv-id').getValue() + '_' + r.result.object.previous_category); if (node) node.destroy(); t.refreshNode(u,true); } } ,changeEditor: function() { this.cleanupEditor(); this.submit(); } ,cleanupEditor: function() { if (MODx.onSaveEditor) { var fld = Ext.getCmp('modx-tv-default-text'); MODx.onSaveEditor(fld); } } ,toggleStaticFile: function(cb) { var flds = ['modx-tv-static-file','modx-tv-static-file-help','modx-tv-static-source','modx-tv-static-source-help']; var fld,i; if (cb.checked) { for (i in flds) { fld = Ext.getCmp(flds[i]); if (fld) { fld.show(); } } } else { for (i in flds) { fld = Ext.getCmp(flds[i]); if (fld) { fld.hide(); } } } } }); Ext.reg('modx-panel-tv',MODx.panel.TV); MODx.panel.TVInputProperties = function(config) { config = config || {}; Ext.applyIf(config,{ id: 'modx-panel-tv-input-properties' ,title: _('tv_input_options') ,header: false ,border: false ,defaults: { border: false } ,cls: 'container form-with-labels' ,items: [{ html: _('tv_input_options_msg') ,bodyCssClass: 'panel-desc' ,itemId: 'desc-tv-input-properties' },{ layout: 'form' ,border: false ,cls:'main-wrapper' ,labelAlign: 'top' ,labelSeparator: '' ,items: [{ xtype: 'modx-combo-tv-input-type' ,fieldLabel: _('tv_type') ,description: MODx.expandHelp ? '' : _('tv_type_desc') ,name: 'type' ,id: 'modx-tv-type' ,itemid: 'fld-type' ,anchor: '100%' ,value: config.record.type || 'text' ,listeners: { 'select': {fn:this.showInputProperties,scope:this} } },{ xtype: 'label' ,forId: 'modx-tv-type' ,html: _('tv_type_desc') ,cls: 'desc-under' },{ xtype: 'textarea' ,fieldLabel: _('tv_elements') ,description: MODx.expandHelp ? '' : _('tv_elements_desc') ,name: 'els' ,id: 'modx-tv-elements' ,itemId: 'fld-els' ,anchor: '100%' ,grow: true ,maxHeight: 160 ,value: config.record.elements || '' ,listeners: { 'change': {fn:this.markPanelDirty,scope:this} } },{ xtype: MODx.expandHelp ? 'label' : 'hidden' ,forId: 'modx-tv-elements' ,html: _('tv_elements_desc') ,cls: 'desc-under' },{ xtype: 'textarea' ,fieldLabel: _('tv_default') ,description: MODx.expandHelp ? '' : _('tv_default_desc') ,name: 'default_text' ,id: 'modx-tv-default-text' ,itemId: 'fld-default_text' ,anchor: '100%' ,grow: true ,maxHeight: 250 ,value: config.record.default_text || '' ,listeners: { 'change': {fn:this.markPanelDirty,scope:this} } },{ xtype: MODx.expandHelp ? 'label' : 'hidden' ,forId: 'modx-tv-default-text' ,html: _('tv_default_desc') ,cls: 'desc-under' },{ html: '<hr />' ,anchor: '100%' ,border: false },{ id: 'modx-input-props' ,autoHeight: true }] }] }); MODx.panel.TVInputProperties.superclass.constructor.call(this,config); }; Ext.extend(MODx.panel.TVInputProperties,MODx.Panel,{ markPanelDirty: function() { Ext.getCmp('modx-panel-tv').markDirty(); } ,showInputProperties: function(cb,rc,i) { this.markPanelDirty(); var pu = Ext.get('modx-input-props').getUpdater(); pu.loadScripts = true; try { pu.update({ url: MODx.config.connectors_url+'element/tv/renders.php' ,method: 'GET' ,params: { 'action': 'getInputProperties' ,'context': 'mgr' ,'tv': this.config.record.id ,'type': cb.getValue() || 'default' } ,scripts: true }); } catch(e) {MODx.debug(e);} } }); Ext.reg('modx-panel-tv-input-properties',MODx.panel.TVInputProperties); MODx.panel.TVOutputProperties = function(config) { config = config || {}; Ext.applyIf(config,{ id: 'modx-panel-tv-output-properties' ,title: _('tv_output_options') ,header: false ,layout: 'form' ,cls: 'container form-with-labels' ,defaults: {border: false} ,items: [{ html: _('tv_output_options_msg') ,bodyCssClass: 'panel-desc' ,itemId: 'desc-tv-output-properties' },{ layout: 'form' ,border: false ,cls:'main-wrapper' ,labelAlign: 'top' ,items: [{ xtype: 'modx-combo-tv-widget' ,fieldLabel: _('tv_output_type') ,name: 'display' ,hiddenName: 'display' ,id: 'modx-tv-display' ,itemId: 'fld-display' ,value: config.record.display || 'default' ,anchor: '100%' ,listeners: { 'select': {fn:this.showOutputProperties,scope:this} } },{ xtype: MODx.expandHelp ? 'label' : 'hidden' ,labelSeparator: '' ,forId: 'modx-tv-display' ,html: _('tv_output_type_desc') ,cls: 'desc-under' },{ id: 'modx-widget-props' ,autoHeight: true }] }] }); MODx.panel.TVOutputProperties.superclass.constructor.call(this,config); }; Ext.extend(MODx.panel.TVOutputProperties,MODx.Panel,{ showOutputProperties: function(cb,rc,i) { Ext.getCmp('modx-panel-tv').markDirty(); var pu = Ext.get('modx-widget-props').getUpdater(); pu.loadScripts = true; try { pu.update({ url: MODx.config.connectors_url+'element/tv/renders.php' ,method: 'GET' ,params: { 'action': 'getProperties' ,'context': 'mgr' ,'tv': this.config.record.id ,'type': cb.getValue() || 'default' } ,scripts: true }); } catch(e) {MODx.debug(e);} } }); Ext.reg('modx-panel-tv-output-properties',MODx.panel.TVOutputProperties); MODx.grid.ElementSources = function(config) { var src = new MODx.combo.MediaSource(); src.getStore().load(); config = config || {}; Ext.applyIf(config,{ id: 'modx-grid-element-sources' ,fields: ['context_key','source','name'] ,autoHeight: true ,primaryKey: 'id' ,columns: [{ header: _('context') ,dataIndex: 'context_key' },{ header: _('source') ,dataIndex: 'source' ,xtype: 'combocolumn' ,editor: src ,gridId: 'modx-grid-element-sources' }] }); MODx.grid.ElementSources.superclass.constructor.call(this,config); this.propRecord = Ext.data.Record.create(['context_key','source']); }; Ext.extend(MODx.grid.ElementSources,MODx.grid.LocalGrid,{ getMenu: function() { return []; } }); Ext.reg('modx-grid-element-sources',MODx.grid.ElementSources);