mirror of
				https://gitlab.ub.uni-bielefeld.de/sfb1288inf/nopaque.git
				synced 2025-11-04 04:12:45 +00:00 
			
		
		
		
	Huge List class update
This commit is contained in:
		@@ -104,7 +104,7 @@ class CorpusAnalysisStaticVisualization {
 | 
				
			|||||||
  renderTextInfoList() {
 | 
					  renderTextInfoList() {
 | 
				
			||||||
    let corpusData = this.data.corpus.o.staticData;
 | 
					    let corpusData = this.data.corpus.o.staticData;
 | 
				
			||||||
    let corpusTextInfoListElement = document.querySelector('.corpus-text-info-list');
 | 
					    let corpusTextInfoListElement = document.querySelector('.corpus-text-info-list');
 | 
				
			||||||
    let corpusTextInfoList = new CorpusTextInfoList(corpusTextInfoListElement);
 | 
					    let corpusTextInfoList = new ResourceLists.CorpusTextInfoList(corpusTextInfoListElement);
 | 
				
			||||||
    let texts = corpusData.s_attrs.text.lexicon;
 | 
					    let texts = corpusData.s_attrs.text.lexicon;
 | 
				
			||||||
    let textData = [];
 | 
					    let textData = [];
 | 
				
			||||||
    for (let i = 0; i < Object.entries(texts).length; i++) {
 | 
					    for (let i = 0; i < Object.entries(texts).length; i++) {
 | 
				
			||||||
@@ -213,7 +213,7 @@ class CorpusAnalysisStaticVisualization {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  async renderTokenList() {
 | 
					  async renderTokenList() {
 | 
				
			||||||
    let corpusTokenListElement = document.querySelector('.corpus-token-list');
 | 
					    let corpusTokenListElement = document.querySelector('.corpus-token-list');
 | 
				
			||||||
    let corpusTokenList = new CorpusTokenList(corpusTokenListElement);
 | 
					    let corpusTokenList = new ResourceLists.CorpusTokenList(corpusTokenListElement);
 | 
				
			||||||
    let filteredData = this.filterData();
 | 
					    let filteredData = this.filterData();
 | 
				
			||||||
    let stopwords = this.data.stopwords;
 | 
					    let stopwords = this.data.stopwords;
 | 
				
			||||||
    if (this.data.stopwords === undefined) {
 | 
					    if (this.data.stopwords === undefined) {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -3,9 +3,9 @@ var ResourceDisplays = {};
 | 
				
			|||||||
ResourceDisplays.autoInit = () => {
 | 
					ResourceDisplays.autoInit = () => {
 | 
				
			||||||
  for (let propertyName in ResourceDisplays) {
 | 
					  for (let propertyName in ResourceDisplays) {
 | 
				
			||||||
    let property = ResourceDisplays[propertyName];
 | 
					    let property = ResourceDisplays[propertyName];
 | 
				
			||||||
    // Call autoInit of all properties that are subclasses of `ResourceDisplays.BaseDisplay`.
 | 
					    // Call autoInit of all properties that are subclasses of `ResourceDisplays.ResourceDisplay`.
 | 
				
			||||||
    // This does not include `ResourceDisplays.BaseDisplay` itself.
 | 
					    // This does not include `ResourceDisplays.ResourceDisplay` itself.
 | 
				
			||||||
    if (property.prototype instanceof ResourceDisplays.BaseDisplay) {
 | 
					    if (property.prototype instanceof ResourceDisplays.ResourceDisplay) {
 | 
				
			||||||
      // Check if the static `htmlClass` property is defined.
 | 
					      // Check if the static `htmlClass` property is defined.
 | 
				
			||||||
      if (property.htmlClass === undefined) {return;}
 | 
					      if (property.htmlClass === undefined) {return;}
 | 
				
			||||||
      // Gather all HTML elements that have the `this.htmlClass` class
 | 
					      // Gather all HTML elements that have the `this.htmlClass` class
 | 
				
			||||||
@@ -15,4 +15,4 @@ ResourceDisplays.autoInit = () => {
 | 
				
			|||||||
      for (let displayElement of displayElements) {new property(displayElement);}
 | 
					      for (let displayElement of displayElements) {new property(displayElement);}
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					};
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,9 +1,5 @@
 | 
				
			|||||||
class AdminUserList extends ResourceList {
 | 
					ResourceLists.AdminUserList = class AdminUserList extends ResourceLists.ResourceList {
 | 
				
			||||||
  static autoInit() {
 | 
					  static htmlClass = 'admin-user-list';
 | 
				
			||||||
    for (let adminUserListElement of document.querySelectorAll('.admin-user-list:not(.no-autoinit)')) {
 | 
					 | 
				
			||||||
      new AdminUserList(adminUserListElement);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  constructor(listContainerElement, options = {}) {
 | 
					  constructor(listContainerElement, options = {}) {
 | 
				
			||||||
    super(listContainerElement, options);
 | 
					    super(listContainerElement, options);
 | 
				
			||||||
@@ -108,4 +104,4 @@ class AdminUserList extends ResourceList {
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					};
 | 
				
			||||||
@@ -1,9 +1,5 @@
 | 
				
			|||||||
class CorpusFileList extends ResourceList {
 | 
					ResourceLists.CorpusFileList = class CorpusFileList extends ResourceLists.ResourceList {
 | 
				
			||||||
  static autoInit() {
 | 
					  static htmlClass = 'corpus-file-list';
 | 
				
			||||||
    for (let corpusFileListElement of document.querySelectorAll('.corpus-file-list:not(.no-autoinit)')) {
 | 
					 | 
				
			||||||
      new CorpusFileList(corpusFileListElement);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  constructor(listContainerElement, options = {}) {
 | 
					  constructor(listContainerElement, options = {}) {
 | 
				
			||||||
    super(listContainerElement, options);
 | 
					    super(listContainerElement, options);
 | 
				
			||||||
@@ -369,4 +365,4 @@ class CorpusFileList extends ResourceList {
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					};
 | 
				
			||||||
@@ -1,9 +1,5 @@
 | 
				
			|||||||
class CorpusFollowerList extends ResourceList {
 | 
					ResourceLists.CorpusFollowerList = class CorpusFollowerList extends ResourceLists.ResourceList {
 | 
				
			||||||
  static autoInit() {
 | 
					  static htmlClass = 'corpus-follower-list';
 | 
				
			||||||
    for (let corpusFollowerListElement of document.querySelectorAll('.corpus-follower-list:not(.no-autoinit)')) {
 | 
					 | 
				
			||||||
      new CorpusFollowerList(corpusFollowerListElement);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  constructor(listContainerElement, options = {}) {
 | 
					  constructor(listContainerElement, options = {}) {
 | 
				
			||||||
    super(listContainerElement, options);
 | 
					    super(listContainerElement, options);
 | 
				
			||||||
@@ -196,4 +192,4 @@ class CorpusFollowerList extends ResourceList {
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					};
 | 
				
			||||||
@@ -1,9 +1,5 @@
 | 
				
			|||||||
class CorpusList extends ResourceList {
 | 
					ResourceLists.CorpusList = class CorpusList extends ResourceLists.ResourceList {
 | 
				
			||||||
  static autoInit() {
 | 
					  static htmlClass = 'corpus-list';
 | 
				
			||||||
    for (let corpusListElement of document.querySelectorAll('.corpus-list:not(.no-autoinit)')) {
 | 
					 | 
				
			||||||
      new CorpusList(corpusListElement);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  constructor(listContainerElement, options = {}) {
 | 
					  constructor(listContainerElement, options = {}) {
 | 
				
			||||||
    super(listContainerElement, options);
 | 
					    super(listContainerElement, options);
 | 
				
			||||||
@@ -370,4 +366,4 @@ class CorpusList extends ResourceList {
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					};
 | 
				
			||||||
@@ -1,10 +1,5 @@
 | 
				
			|||||||
class CorpusTextInfoList extends ResourceList {
 | 
					ResourceLists.CorpusTextInfoList = class CorpusTextInfoList extends ResourceLists.ResourceList {
 | 
				
			||||||
 | 
					  static htmlClass = 'corpus-text-info-list';
 | 
				
			||||||
  static autoInit() {
 | 
					 | 
				
			||||||
    for (let corpusTextInfoListElement of document.querySelectorAll('.corpus-text-info-list:not(.no-autoinit)')) {
 | 
					 | 
				
			||||||
      new CorpusTextInfoList(corpusTextInfoListElement);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  static defaultOptions = {
 | 
					  static defaultOptions = {
 | 
				
			||||||
    page: 5
 | 
					    page: 5
 | 
				
			||||||
@@ -12,7 +7,7 @@ class CorpusTextInfoList extends ResourceList {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  constructor(listContainerElement, options = {}) {
 | 
					  constructor(listContainerElement, options = {}) {
 | 
				
			||||||
    let _options = Utils.mergeObjectsDeep(
 | 
					    let _options = Utils.mergeObjectsDeep(
 | 
				
			||||||
      CorpusTextInfoList.defaultOptions,
 | 
					      ResourceLists.CorpusTextInfoList.defaultOptions,
 | 
				
			||||||
      options
 | 
					      options
 | 
				
			||||||
    );
 | 
					    );
 | 
				
			||||||
    super(listContainerElement, _options);
 | 
					    super(listContainerElement, _options);
 | 
				
			||||||
@@ -109,4 +104,4 @@ class CorpusTextInfoList extends ResourceList {
 | 
				
			|||||||
    clickedSortElement.style.color = '#aa9cc9';
 | 
					    clickedSortElement.style.color = '#aa9cc9';
 | 
				
			||||||
    clickedSortElement.innerHTML = clickedSortElement.classList.contains('asc') ? 'arrow_drop_down' : 'arrow_drop_up';
 | 
					    clickedSortElement.innerHTML = clickedSortElement.classList.contains('asc') ? 'arrow_drop_down' : 'arrow_drop_up';
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					};
 | 
				
			||||||
@@ -1,9 +1,5 @@
 | 
				
			|||||||
class CorpusTokenList extends ResourceList {
 | 
					ResourceLists.CorpusTokenList = class CorpusTokenList extends ResourceLists.ResourceList {
 | 
				
			||||||
  static autoInit() {
 | 
					  static htmlClass = 'corpus-token-list';
 | 
				
			||||||
    for (let corpusTokenListElement of document.querySelectorAll('.corpus-token-list:not(.no-autoinit)')) {
 | 
					 | 
				
			||||||
      new CorpusTokenList(corpusTokenListElement);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  static defaultOptions = {
 | 
					  static defaultOptions = {
 | 
				
			||||||
    page: 7
 | 
					    page: 7
 | 
				
			||||||
@@ -11,7 +7,7 @@ class CorpusTokenList extends ResourceList {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  constructor(listContainerElement, options = {}) {
 | 
					  constructor(listContainerElement, options = {}) {
 | 
				
			||||||
    let _options = Utils.mergeObjectsDeep(
 | 
					    let _options = Utils.mergeObjectsDeep(
 | 
				
			||||||
      CorpusTokenList.defaultOptions,
 | 
					      ResourceLists.CorpusTokenList.defaultOptions,
 | 
				
			||||||
      options
 | 
					      options
 | 
				
			||||||
    );
 | 
					    );
 | 
				
			||||||
    super(listContainerElement, _options);
 | 
					    super(listContainerElement, _options);
 | 
				
			||||||
@@ -138,4 +134,4 @@ class CorpusTokenList extends ResourceList {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					};
 | 
				
			||||||
@@ -1,4 +1,6 @@
 | 
				
			|||||||
class DetailledPublicCorpusList extends CorpusList {
 | 
					ResourceLists.DetailedPublicCorpusList = class DetailedPublicCorpusList extends ResourceLists.ResourceList {
 | 
				
			||||||
 | 
					  static htmlClass = 'detailed-public-corpus-list';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  get item() {
 | 
					  get item() {
 | 
				
			||||||
    return (values) => {
 | 
					    return (values) => {
 | 
				
			||||||
      return `
 | 
					      return `
 | 
				
			||||||
@@ -68,4 +70,4 @@ class DetailledPublicCorpusList extends CorpusList {
 | 
				
			|||||||
      'current-user-is-following': Object.values(corpus.corpus_follower_associations).some(association => association.follower.id === currentUserId)
 | 
					      'current-user-is-following': Object.values(corpus.corpus_follower_associations).some(association => association.follower.id === currentUserId)
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					};
 | 
				
			||||||
							
								
								
									
										18
									
								
								app/static/js/resource-lists/index.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								app/static/js/resource-lists/index.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,18 @@
 | 
				
			|||||||
 | 
					var ResourceLists = {};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					ResourceLists.autoInit = () => {
 | 
				
			||||||
 | 
					  for (let propertyName in ResourceLists) {
 | 
				
			||||||
 | 
					    let property = ResourceLists[propertyName];
 | 
				
			||||||
 | 
					    // Call autoInit of all properties that are subclasses of `ResourceLists.ResourceList`.
 | 
				
			||||||
 | 
					    // This does not include `ResourceLists.ResourceList` itself.
 | 
				
			||||||
 | 
					    if (property.prototype instanceof ResourceLists.ResourceList) {
 | 
				
			||||||
 | 
					      // Check if the static `htmlClass` property is defined.
 | 
				
			||||||
 | 
					      if (property.htmlClass === undefined) {return;}
 | 
				
			||||||
 | 
					      // Gather all HTML elements that have the `this.htmlClass` class
 | 
				
			||||||
 | 
					      // and do not have the `no-autoinit` class.
 | 
				
			||||||
 | 
					      let listElements = document.querySelectorAll(`.${property.htmlClass}:not(.no-autoinit)`);
 | 
				
			||||||
 | 
					      // Create an instance of this class for each display element.
 | 
				
			||||||
 | 
					      for (let listElement of listElements) {new property(listElement);}
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
@@ -1,9 +1,5 @@
 | 
				
			|||||||
class JobInputList extends ResourceList {
 | 
					ResourceLists.JobInputList = class JobInputList extends ResourceLists.ResourceList {
 | 
				
			||||||
  static autoInit() {
 | 
					  static htmlClass = 'job-input-list';
 | 
				
			||||||
    for (let jobInputListElement of document.querySelectorAll('.job-input-list:not(.no-autoinit)')) {
 | 
					 | 
				
			||||||
      new JobInputList(jobInputListElement);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  constructor(listContainerElement, options = {}) {
 | 
					  constructor(listContainerElement, options = {}) {
 | 
				
			||||||
    super(listContainerElement, options);
 | 
					    super(listContainerElement, options);
 | 
				
			||||||
@@ -90,4 +86,4 @@ class JobInputList extends ResourceList {
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					};
 | 
				
			||||||
@@ -1,9 +1,5 @@
 | 
				
			|||||||
class JobList extends ResourceList {
 | 
					ResourceLists.JobList = class JobList extends ResourceLists.ResourceList {
 | 
				
			||||||
  static autoInit() {
 | 
					  static htmlClass = 'job-list';
 | 
				
			||||||
    for (let jobListElement of document.querySelectorAll('.job-list:not(.no-autoinit)')) {
 | 
					 | 
				
			||||||
      new JobList(jobListElement);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  constructor(listContainerElement, options = {}) {
 | 
					  constructor(listContainerElement, options = {}) {
 | 
				
			||||||
    super(listContainerElement, options);
 | 
					    super(listContainerElement, options);
 | 
				
			||||||
@@ -323,4 +319,4 @@ class JobList extends ResourceList {
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					};
 | 
				
			||||||
@@ -1,9 +1,5 @@
 | 
				
			|||||||
class JobResultList extends ResourceList {
 | 
					ResourceLists.JobResultList = class JobResultList extends ResourceLists.ResourceList {
 | 
				
			||||||
  static autoInit() {
 | 
					  static htmlClass = 'job-result-list';
 | 
				
			||||||
    for (let jobResultListElement of document.querySelectorAll('.job-result-list:not(.no-autoinit)')) {
 | 
					 | 
				
			||||||
      new JobResultList(jobResultListElement);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  constructor(listContainerElement, options = {}) {
 | 
					  constructor(listContainerElement, options = {}) {
 | 
				
			||||||
    super(listContainerElement, options);
 | 
					    super(listContainerElement, options);
 | 
				
			||||||
@@ -115,4 +111,4 @@ class JobResultList extends ResourceList {
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					};
 | 
				
			||||||
@@ -1,4 +1,6 @@
 | 
				
			|||||||
class PublicCorpusList extends CorpusList {
 | 
					ResourceLists.PublicCorpusList = class PublicCorpusList extends ResourceLists.ResourceList {
 | 
				
			||||||
 | 
					  static htmlClass = 'public-corpus-list';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  get item() {
 | 
					  get item() {
 | 
				
			||||||
    return (values) => {
 | 
					    return (values) => {
 | 
				
			||||||
      return `
 | 
					      return `
 | 
				
			||||||
@@ -52,4 +54,4 @@ class PublicCorpusList extends CorpusList {
 | 
				
			|||||||
      <ul class="pagination"></ul>
 | 
					      <ul class="pagination"></ul>
 | 
				
			||||||
    `.trim();
 | 
					    `.trim();
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					};
 | 
				
			||||||
@@ -1,31 +1,4 @@
 | 
				
			|||||||
var ResourceLists = {};
 | 
					ResourceLists.ResourceList = class ResourceList {
 | 
				
			||||||
 | 
					 | 
				
			||||||
ResourceLists.autoInit = () => {
 | 
					 | 
				
			||||||
  for (let propertyName in ResourceLists) {
 | 
					 | 
				
			||||||
    let property = ResourceLists[propertyName];
 | 
					 | 
				
			||||||
    // Call autoInit of all properties that are subclasses of `ResourceLists.BaseList`.
 | 
					 | 
				
			||||||
    // This does not include `ResourceLists.BaseList` itself.
 | 
					 | 
				
			||||||
    if (property.prototype instanceof ResourceLists.BaseList) {
 | 
					 | 
				
			||||||
      // Check if the static `htmlClass` property is defined.
 | 
					 | 
				
			||||||
      if (property.htmlClass === undefined) {return;}
 | 
					 | 
				
			||||||
      // Gather all HTML elements that have the `this.htmlClass` class
 | 
					 | 
				
			||||||
      // and do not have the `no-autoinit` class.
 | 
					 | 
				
			||||||
      let listElements = document.querySelectorAll(`.${property.htmlClass}:not(.no-autoinit)`);
 | 
					 | 
				
			||||||
      // Create an instance of this class for each display element.
 | 
					 | 
				
			||||||
      for (let listElement of listElements) {new property(listElement);}
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
ResourceLists.defaultOptions = {
 | 
					 | 
				
			||||||
  page: 5,
 | 
					 | 
				
			||||||
  pagination: {
 | 
					 | 
				
			||||||
    innerWindow: 2,
 | 
					 | 
				
			||||||
    outerWindow: 2
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
ResourceLists.BaseList = class BaseList {
 | 
					 | 
				
			||||||
  /* A wrapper class for the list.js list.
 | 
					  /* A wrapper class for the list.js list.
 | 
				
			||||||
   * This class is not meant to be used directly, instead it should be used as
 | 
					   * This class is not meant to be used directly, instead it should be used as
 | 
				
			||||||
   * a base class for concrete resource list implementations.
 | 
					   * a base class for concrete resource list implementations.
 | 
				
			||||||
@@ -33,6 +6,14 @@ ResourceLists.BaseList = class BaseList {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  static htmlClass;
 | 
					  static htmlClass;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  static defaultOptions = {
 | 
				
			||||||
 | 
					    page: 5,
 | 
				
			||||||
 | 
					    pagination: {
 | 
				
			||||||
 | 
					      innerWindow: 2,
 | 
				
			||||||
 | 
					      outerWindow: 2
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  constructor(listContainerElement, options = {}) {
 | 
					  constructor(listContainerElement, options = {}) {
 | 
				
			||||||
    if ('items' in options) {
 | 
					    if ('items' in options) {
 | 
				
			||||||
      throw '"items" is not supported as an option, define it as a getter in the list class';
 | 
					      throw '"items" is not supported as an option, define it as a getter in the list class';
 | 
				
			||||||
@@ -42,7 +23,7 @@ ResourceLists.BaseList = class BaseList {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
    let _options = Utils.mergeObjectsDeep(
 | 
					    let _options = Utils.mergeObjectsDeep(
 | 
				
			||||||
      {item: this.item, valueNames: this.valueNames},
 | 
					      {item: this.item, valueNames: this.valueNames},
 | 
				
			||||||
      ResourceLists.defaultOptions,
 | 
					      ResourceLists.ResourceList.defaultOptions,
 | 
				
			||||||
      options
 | 
					      options
 | 
				
			||||||
    );
 | 
					    );
 | 
				
			||||||
    this.listContainerElement = listContainerElement;
 | 
					    this.listContainerElement = listContainerElement;
 | 
				
			||||||
@@ -1,9 +1,5 @@
 | 
				
			|||||||
class SpaCyNLPPipelineModelList extends ResourceList {
 | 
					ResourceLists.SpaCyNLPPipelineModelList = class SpaCyNLPPipelineModelList extends ResourceLists.ResourceList {
 | 
				
			||||||
  static autoInit() {
 | 
					  static htmlClass = 'spacy-nlp-pipeline-model-list';
 | 
				
			||||||
    for (let spaCyNLPPipelineModelListElement of document.querySelectorAll('.spacy-nlp-pipeline-model-list:not(.no-autoinit)')) {
 | 
					 | 
				
			||||||
      new SpaCyNLPPipelineModelList(spaCyNLPPipelineModelListElement);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  constructor(listContainerElement, options = {}) {
 | 
					  constructor(listContainerElement, options = {}) {
 | 
				
			||||||
    super(listContainerElement, options);
 | 
					    super(listContainerElement, options);
 | 
				
			||||||
@@ -220,4 +216,4 @@ class SpaCyNLPPipelineModelList extends ResourceList {
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					};
 | 
				
			||||||
@@ -1,9 +1,5 @@
 | 
				
			|||||||
class TesseractOCRPipelineModelList extends ResourceList {
 | 
					ResourceLists.TesseractOCRPipelineModelList = class TesseractOCRPipelineModelList extends ResourceLists.ResourceList {
 | 
				
			||||||
  static autoInit() {
 | 
					  static htmlClass = 'tesseract-ocr-pipeline-model-list';
 | 
				
			||||||
    for (let tesseractOCRPipelineModelListElement of document.querySelectorAll('.tesseract-ocr-pipeline-model-list:not(.no-autoinit)')) {
 | 
					 | 
				
			||||||
      new TesseractOCRPipelineModelList(tesseractOCRPipelineModelListElement);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  constructor(listContainerElement, options = {}) {
 | 
					  constructor(listContainerElement, options = {}) {
 | 
				
			||||||
    super(listContainerElement, options);
 | 
					    super(listContainerElement, options);
 | 
				
			||||||
@@ -229,4 +225,4 @@ class TesseractOCRPipelineModelList extends ResourceList {
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					};
 | 
				
			||||||
@@ -1,9 +1,5 @@
 | 
				
			|||||||
class UserList extends ResourceList {
 | 
					ResourceLists.UserList = class UserList extends ResourceLists.ResourceList {
 | 
				
			||||||
  static autoInit() {
 | 
					  static htmlClass = 'user-list';
 | 
				
			||||||
    for (let userListElement of document.querySelectorAll('.user-list:not(.no-autoinit)')) {
 | 
					 | 
				
			||||||
      new UserList(userListElement);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  constructor(listContainerElement, options = {}) {
 | 
					  constructor(listContainerElement, options = {}) {
 | 
				
			||||||
    super(listContainerElement, options);
 | 
					    super(listContainerElement, options);
 | 
				
			||||||
@@ -101,4 +97,4 @@ class UserList extends ResourceList {
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					};
 | 
				
			||||||
@@ -57,22 +57,23 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
{%- assets
 | 
					{%- assets
 | 
				
			||||||
  filters='rjsmin',
 | 
					  filters='rjsmin',
 | 
				
			||||||
  output='gen/ResourceLists.%(version)s.js',
 | 
					  output='gen/resource-lists.%(version)s.js',
 | 
				
			||||||
  'js/ResourceLists/ResourceList.js',
 | 
					  'js/resource-lists/index.js',
 | 
				
			||||||
  'js/ResourceLists/CorpusFileList.js',
 | 
					  'js/resource-lists/resource-list.js',
 | 
				
			||||||
  'js/ResourceLists/CorpusList.js',
 | 
					  'js/resource-lists/admin-user-list.js',
 | 
				
			||||||
  'js/ResourceLists/PublicCorpusList.js',
 | 
					  'js/resource-lists/corpus-file-list.js',
 | 
				
			||||||
  'js/ResourceLists/JobList.js',
 | 
					  'js/resource-lists/corpus-follower-list.js',
 | 
				
			||||||
  'js/ResourceLists/JobInputList.js',
 | 
					  'js/resource-lists/corpus-list.js',
 | 
				
			||||||
  'js/ResourceLists/JobResultList.js',
 | 
					  'js/resource-lists/corpus-text-info-list.js',
 | 
				
			||||||
  'js/ResourceLists/SpacyNLPPipelineModelList.js',
 | 
					  'js/resource-lists/corpus-token-list.js',
 | 
				
			||||||
  'js/ResourceLists/TesseractOCRPipelineModelList.js',
 | 
					  'js/resource-lists/detailed-public-corpus-list.js',
 | 
				
			||||||
  'js/ResourceLists/UserList.js',
 | 
					  'js/resource-lists/job-input-list.js',
 | 
				
			||||||
  'js/ResourceLists/AdminUserList.js',
 | 
					  'js/resource-lists/job-list.js',
 | 
				
			||||||
  'js/ResourceLists/CorpusFollowerList.js',
 | 
					  'js/resource-lists/job-result-list.js',
 | 
				
			||||||
  'js/ResourceLists/CorpusTextInfoList.js',
 | 
					  'js/resource-lists/public-corpus-list.js',
 | 
				
			||||||
  'js/ResourceLists/DetailledPublicCorpusList.js',
 | 
					  'js/resource-lists/spacy-nlp-pipeline-model-list.js',
 | 
				
			||||||
  'js/ResourceLists/CorpusTokenList.js'
 | 
					  'js/resource-lists/tesseract-ocr-pipeline-model-list.js',
 | 
				
			||||||
 | 
					  'js/resource-lists/user-list.js'
 | 
				
			||||||
%}
 | 
					%}
 | 
				
			||||||
<script src="{{ ASSET_URL }}"></script>
 | 
					<script src="{{ ASSET_URL }}"></script>
 | 
				
			||||||
{%- endassets %}
 | 
					{%- endassets %}
 | 
				
			||||||
@@ -143,7 +144,7 @@
 | 
				
			|||||||
    {alignment: 'right', constrainWidth: false, coverTrigger: false}
 | 
					    {alignment: 'right', constrainWidth: false, coverTrigger: false}
 | 
				
			||||||
  );
 | 
					  );
 | 
				
			||||||
  ResourceDisplays.autoInit();
 | 
					  ResourceDisplays.autoInit();
 | 
				
			||||||
  ResourceList.autoInit();
 | 
					  ResourceLists.autoInit();
 | 
				
			||||||
  Forms.autoInit();
 | 
					  Forms.autoInit();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  // Display flashed messages
 | 
					  // Display flashed messages
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -17,7 +17,7 @@
 | 
				
			|||||||
{{ super() }}
 | 
					{{ super() }}
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
  let corpusListElement = document.querySelector('#corpus-list');
 | 
					  let corpusListElement = document.querySelector('#corpus-list');
 | 
				
			||||||
  let corpusList = new CorpusList(corpusListElement);
 | 
					  let corpusList = new ResourceLists.CorpusList(corpusListElement);
 | 
				
			||||||
  corpusList.add(
 | 
					  corpusList.add(
 | 
				
			||||||
    [
 | 
					    [
 | 
				
			||||||
      {% for corpus in corpora %}
 | 
					      {% for corpus in corpora %}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -22,7 +22,7 @@
 | 
				
			|||||||
{{ super() }}
 | 
					{{ super() }}
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
  let adminUserListElement = document.querySelector('#admin-user-list');
 | 
					  let adminUserListElement = document.querySelector('#admin-user-list');
 | 
				
			||||||
  let adminUserList = new AdminUserList(adminUserListElement);
 | 
					  let adminUserList = new ResourceLists.AdminUserList(adminUserListElement);
 | 
				
			||||||
  adminUserList.add(
 | 
					  adminUserList.add(
 | 
				
			||||||
    [
 | 
					    [
 | 
				
			||||||
      {% for user in users %}
 | 
					      {% for user in users %}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -242,7 +242,7 @@
 | 
				
			|||||||
{{ super() }}
 | 
					{{ super() }}
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
let publicCorpusFileList = new CorpusFileList(document.querySelector('#corpus-file-list'));
 | 
					let publicCorpusFileList = new ResourceLists.CorpusFileList(document.querySelector('#corpus-file-list'));
 | 
				
			||||||
publicCorpusFileList.add(
 | 
					publicCorpusFileList.add(
 | 
				
			||||||
  [
 | 
					  [
 | 
				
			||||||
    {% for corpus_file in corpus.files %}
 | 
					    {% for corpus_file in corpus.files %}
 | 
				
			||||||
@@ -259,7 +259,7 @@ refreshButton.addEventListener('click', () => {
 | 
				
			|||||||
{% endif %}
 | 
					{% endif %}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
{% if cfr.has_permission('MANAGE_FOLLOWERS') %}
 | 
					{% if cfr.has_permission('MANAGE_FOLLOWERS') %}
 | 
				
			||||||
let publicCorpusFollowerList = new CorpusFollowerList(document.querySelector('.corpus-follower-list'));
 | 
					let publicCorpusFollowerList = new ResourceLists.CorpusFollowerList(document.querySelector('.corpus-follower-list'));
 | 
				
			||||||
publicCorpusFollowerList.add(
 | 
					publicCorpusFollowerList.add(
 | 
				
			||||||
  [
 | 
					  [
 | 
				
			||||||
    {% for cfa in cfas %}
 | 
					    {% for cfa in cfas %}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -62,7 +62,7 @@
 | 
				
			|||||||
{% block scripts %}
 | 
					{% block scripts %}
 | 
				
			||||||
{{ super() }}
 | 
					{{ super() }}
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
  let userList = new UserList(document.querySelector('.user-list'));
 | 
					  let userList = new ResourceLists.UserList(document.querySelector('.user-list'));
 | 
				
			||||||
  userList.add(
 | 
					  userList.add(
 | 
				
			||||||
    [
 | 
					    [
 | 
				
			||||||
      {% for user in users %}
 | 
					      {% for user in users %}
 | 
				
			||||||
@@ -70,7 +70,7 @@
 | 
				
			|||||||
      {% endfor %}
 | 
					      {% endfor %}
 | 
				
			||||||
    ]
 | 
					    ]
 | 
				
			||||||
  );
 | 
					  );
 | 
				
			||||||
  let publicCorpusList = new PublicCorpusList(document.querySelector('.public-corpus-list'));
 | 
					  let publicCorpusList = new ResourceLists.PublicCorpusList(document.querySelector('.public-corpus-list'));
 | 
				
			||||||
  publicCorpusList.add(
 | 
					  publicCorpusList.add(
 | 
				
			||||||
    [
 | 
					    [
 | 
				
			||||||
      {% for corpus in corpora %}
 | 
					      {% for corpus in corpora %}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -122,7 +122,7 @@
 | 
				
			|||||||
{% block scripts %}
 | 
					{% block scripts %}
 | 
				
			||||||
{{ super() }}
 | 
					{{ super() }}
 | 
				
			||||||
<script>
 | 
					<script>
 | 
				
			||||||
let followedCorpusList = new PublicCorpusList(document.querySelector('.followed-corpus-list'));
 | 
					let followedCorpusList = new ResourceLists.PublicCorpusList(document.querySelector('.followed-corpus-list'));
 | 
				
			||||||
followedCorpusList.add(
 | 
					followedCorpusList.add(
 | 
				
			||||||
  [
 | 
					  [
 | 
				
			||||||
    {% for corpus in user.followed_corpora %}
 | 
					    {% for corpus in user.followed_corpora %}
 | 
				
			||||||
@@ -132,7 +132,7 @@ followedCorpusList.add(
 | 
				
			|||||||
    {% endfor %}
 | 
					    {% endfor %}
 | 
				
			||||||
  ]
 | 
					  ]
 | 
				
			||||||
);
 | 
					);
 | 
				
			||||||
let publicCorpusList = new PublicCorpusList(document.querySelector('.public-corpus-list'));
 | 
					let publicCorpusList = new ResourceLists.PublicCorpusList(document.querySelector('.public-corpus-list'));
 | 
				
			||||||
publicCorpusList.add(
 | 
					publicCorpusList.add(
 | 
				
			||||||
  [
 | 
					  [
 | 
				
			||||||
    {% for corpus in user.corpora %}
 | 
					    {% for corpus in user.corpora %}
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user