| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220 |
- /**
- * Loads a grid of TVs assigned to the Template.
- *
- * @class MODx.grid.TemplateTV
- * @extends MODx.grid.Grid
- * @param {Object} config An object of options.
- * @xtype modx-grid-template-tv
- */
- MODx.grid.TemplateTV = function(config) {
- config = config || {};
- var tt = new Ext.ux.grid.CheckColumn({
- header: _('access')
- ,dataIndex: 'access'
- ,width: 70
- ,sortable: true
- });
- Ext.applyIf(config,{
- title: _('template_assignedtv_tab')
- ,id: 'modx-grid-template-tv'
- ,url: MODx.config.connector_url
- ,fields: ['id','name','description','tv_rank','access','perm','category_name','category']
- ,baseParams: {
- action: 'element/template/tv/getlist'
- ,template: config.template
- ,sort: 'tv_rank'
- }
- ,saveParams: {
- template: config.template
- }
- ,width: 800
- ,paging: true
- ,plugins: tt
- ,remoteSort: true
- ,sortBy: 'category_name, tv_rank'
- ,grouping: true
- ,groupBy: 'category_name'
- ,singleText: _('tv')
- ,pluralText: _('tvs')
- ,enableDragDrop: true
- ,ddGroup : 'template-tvs-ddsort'
- ,sm: new Ext.grid.RowSelectionModel({
- singleSelect: true
- ,listeners: {
- beforerowselect: function(sm, idx, keep, record) {
- sm.grid.ddText = '<div>'+ record.data.name +'</div>';
- }
- }
- })
- ,columns: [{
- header: _('name')
- ,dataIndex: 'name'
- ,width: 150
- ,editor: { xtype: 'textfield' ,allowBlank: false }
- ,sortable: true
- },{
- header: _('category')
- ,dataIndex: 'category_name'
- ,width: 150
- ,sortable: true
- },{
- header: _('description')
- ,dataIndex: 'description'
- ,width: 350
- ,editor: { xtype: 'textfield' }
- ,sortable: false
- },tt,{
- header: _('rank')
- ,dataIndex: 'tv_rank'
- ,width: 100
- ,editor: { xtype: 'textfield' ,allowBlank: false }
- ,sortable: true
- }]
- ,tbar: ['->',{
- xtype: 'modx-combo-category'
- ,name: 'filter_category'
- ,hiddenName: 'filter_category'
- ,id: 'modx-temptv-filter-category'
- ,emptyText: _('filter_by_category')
- ,value: ''
- ,allowBlank: true
- ,width: 150
- ,listeners: {
- 'select': {fn: this.filterByCategory, scope:this}
- }
- },{
- xtype: 'textfield'
- ,name: 'search'
- ,id: 'modx-temptv-search'
- ,cls: 'x-form-filter'
- ,emptyText: _('search_ellipsis')
- ,listeners: {
- 'change': {fn: this.search, scope: this}
- ,'render': {fn: function(cmp) {
- new Ext.KeyMap(cmp.getEl(), {
- key: Ext.EventObject.ENTER
- ,fn: this.blur
- ,scope: cmp
- });
- },scope:this}
- }
- },{
- xtype: 'button'
- ,id: 'modx-filter-clear'
- ,cls: 'x-form-filter-clear'
- ,text: _('filter_clear')
- ,listeners: {
- 'click': {fn: this.clearFilter, scope: this},
- 'mouseout': { fn: function(evt){
- this.removeClass('x-btn-focus');
- }
- }
- }
- }]
- });
- MODx.grid.TemplateTV.superclass.constructor.call(this,config);
- this.on('render', this.prepareDDSort, this);
- };
- Ext.extend(MODx.grid.TemplateTV,MODx.grid.Grid,{
- getMenu: function() {
- var r = this.getSelectionModel().getSelected();
- var p = r.data.perm;
- var m = [];
- if (p.indexOf('pedit') != -1) {
- m.push({
- text: _('edit_tv')
- ,handler: this.updateTV
- });
- }
- return m;
- }
- ,updateTV: function(itm,e) {
- MODx.loadPage('element/tv/update', 'id='+this.menu.record.id);
- }
- ,filterByCategory: function(cb,rec,ri) {
- this.getStore().baseParams['category'] = cb.getValue();
- this.getBottomToolbar().changePage(1);
- //this.refresh();
- }
- ,search: function(tf,newValue,oldValue) {
- var nv = newValue || tf;
- this.getStore().baseParams.search = Ext.isEmpty(nv) || Ext.isObject(nv) ? '' : nv;
- Ext.getCmp('modx-temptv-filter-category').setValue('');
- this.getBottomToolbar().changePage(1);
- //this.refresh();
- return true;
- }
- ,clearFilter: function() {
- this.getStore().baseParams = {
- action: 'element/template/tv/getList'
- ,template: this.config.template
- };
- Ext.getCmp('modx-temptv-filter-category').reset();
- Ext.getCmp('modx-temptv-search').setValue('');
- this.getBottomToolbar().changePage(1);
- //this.refresh();
- }
- ,prepareDDSort: function(grid) {
- this.dropTarget = new Ext.dd.DropTarget(grid.getView().mainBody, {
- ddGroup: 'template-tvs-ddsort'
- ,copy: false
- ,notifyOver: function(dragSource, e, data) {
- if (dragSource.getDragData(e)) {
- var targetNode = dragSource.getDragData(e).selections[0];
- var sourceNode = data.selections[0];
- if ((sourceNode.data['category_name'] != targetNode.data['category_name']) ||
- !sourceNode.data['access'] ||
- !targetNode.data['access'] ||
- (sourceNode.data['id'] == targetNode.data['id'])
- ) {
- return this.dropNotAllowed;
- }
- return this.dropAllowed;
- }
- return this.dropNotAllowed;
- }
- ,notifyDrop : function(dragSource, e, data) {
- if (dragSource.getDragData(e)) {
- var targetNode = dragSource.getDragData(e).selections[0];
- var sourceNode = data.selections[0];
- if ((targetNode.id != sourceNode.id) &&
- (targetNode.get('category_name') === sourceNode.get('category_name')) &&
- sourceNode.get('access')
- ) {
- grid.sortTVs(sourceNode, targetNode);
- }
- }
- }
- });
- }
- ,sortTVs: function(sourceNode, targetNode) {
- var store = this.getStore();
- var sourceIdx = store.indexOf(sourceNode);
- var targetIdx = store.indexOf(targetNode);
- // Insert the selection to the target (and remove original selection)
- store.removeAt(sourceIdx);
- store.insert(targetIdx, sourceNode);
- // Extract the store items with the same category_name as the sourceNode to start the index at 0 for each category
- var filteredStore = store.queryBy(function(rec, id) {
- if (rec.get('category_name') === sourceNode.get('category_name')) {
- return true;
- }
- return false;
- }, this);
- // Loop trough the filtered store and re-apply the re-calculated ranks to the store records
- Ext.each(filteredStore.items, function(item, index, allItems) {
- if (sourceNode.get('category_name') === item.get('category_name')) {
- var record = store.getById(item.id);
- record.set('tv_rank', index);
- }
- }, this);
- }
- });
- Ext.reg('modx-grid-template-tv',MODx.grid.TemplateTV);
|