2020-09-16 22:33:53 +08:00
|
|
|
import { AbstractCollectionModel } from 'Model/AbstractCollection';
|
2020-09-15 21:08:08 +08:00
|
|
|
import { AttachmentModel } from 'Model/Attachment';
|
|
|
|
|
|
|
|
'use strict';
|
|
|
|
|
2020-09-16 22:33:53 +08:00
|
|
|
export class AttachmentCollectionModel extends AbstractCollectionModel
|
2020-09-15 21:08:08 +08:00
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @param {?Array} json
|
|
|
|
* @returns {AttachmentCollectionModel}
|
|
|
|
*/
|
2020-09-20 17:15:00 +08:00
|
|
|
static reviveFromJson(items) {
|
2020-09-15 21:08:08 +08:00
|
|
|
let result = new AttachmentCollectionModel;
|
2020-09-16 22:33:53 +08:00
|
|
|
items = this.getFromJSON(items, 'AttachmentCollection') || items;
|
2020-09-15 21:08:08 +08:00
|
|
|
Array.isArray(items) && items.forEach(attachment => {
|
|
|
|
attachment = AttachmentModel.newInstanceFromJson(attachment);
|
|
|
|
if (attachment) {
|
|
|
|
result.push(attachment);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @returns {boolean}
|
|
|
|
*/
|
|
|
|
hasVisible() {
|
|
|
|
return !!this.find(item => !item.isLinked);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param {string} cid
|
|
|
|
* @returns {*}
|
|
|
|
*/
|
|
|
|
findByCid(cid) {
|
|
|
|
cid = cid.replace(/^<+|>+$/, '');
|
2020-09-20 17:15:00 +08:00
|
|
|
return this.find(item => cid === item.cidWithoutTags);
|
2020-09-15 21:08:08 +08:00
|
|
|
}
|
|
|
|
}
|