Files
planka/client/src/models/Label.js

82 lines
1.9 KiB
JavaScript
Raw Normal View History

2019-08-31 04:07:25 +05:00
import { Model, attr, fk } from 'redux-orm';
import ActionTypes from '../constants/ActionTypes';
export default class extends Model {
static modelName = 'Label';
static fields = {
id: attr(),
name: attr(),
color: attr(),
boardId: fk({
to: 'Board',
as: 'board',
relatedName: 'labels',
}),
};
static reducer({ type, payload }, Label) {
switch (type) {
case ActionTypes.LOCATION_CHANGE_HANDLE:
case ActionTypes.CORE_INITIALIZE:
case ActionTypes.PROJECT_MANAGER_CREATE_HANDLE:
case ActionTypes.BOARD_MEMBERSHIP_CREATE_HANDLE:
if (payload.labels) {
payload.labels.forEach((label) => {
Label.upsert(label);
});
}
break;
case ActionTypes.SOCKET_RECONNECT_HANDLE:
Label.all().delete();
if (payload.labels) {
payload.labels.forEach((label) => {
Label.upsert(label);
});
}
break;
case ActionTypes.BOARD_FETCH__SUCCESS:
2020-03-25 00:15:47 +05:00
payload.labels.forEach((label) => {
2019-08-31 04:07:25 +05:00
Label.upsert(label);
});
break;
case ActionTypes.LABEL_CREATE:
case ActionTypes.LABEL_CREATE_HANDLE:
case ActionTypes.LABEL_UPDATE__SUCCESS:
case ActionTypes.LABEL_UPDATE_HANDLE:
Label.upsert(payload.label);
break;
case ActionTypes.LABEL_CREATE__SUCCESS:
Label.withId(payload.localId).delete();
2019-08-31 04:07:25 +05:00
Label.upsert(payload.label);
break;
case ActionTypes.LABEL_UPDATE:
Label.withId(payload.id).update(payload.data);
break;
case ActionTypes.LABEL_DELETE:
Label.withId(payload.id).delete();
break;
case ActionTypes.LABEL_DELETE__SUCCESS:
case ActionTypes.LABEL_DELETE_HANDLE: {
const labelModel = Label.withId(payload.label.id);
2019-08-31 04:07:25 +05:00
if (labelModel) {
labelModel.delete();
}
2019-08-31 04:07:25 +05:00
break;
}
2019-08-31 04:07:25 +05:00
default:
}
}
}