mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-18 23:27:26 +01:00
Added clone ability to challenges.
This commit is contained in:
@@ -52,7 +52,8 @@
|
|||||||
"challengedOwnedFilterHeader": "Ownership",
|
"challengedOwnedFilterHeader": "Ownership",
|
||||||
"challengedOwnedFilter": "Owned",
|
"challengedOwnedFilter": "Owned",
|
||||||
"challengedNotOwnedFilter": "Not Owned",
|
"challengedNotOwnedFilter": "Not Owned",
|
||||||
"challengedEitherOwnedFilter": "Either",
|
"challengedEitherOwnedFilter": "Either",,
|
||||||
"backToChallenges": "Back to all challenges",
|
"backToChallenges": "Back to all challenges",
|
||||||
"prizeValue": "<%= gemcount %> <%= gemicon %> Prize"
|
"prizeValue": "<%= gemcount %> <%= gemicon %> Prize",
|
||||||
|
"clone": "Clone"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -89,6 +89,46 @@ habitrpg.controller("ChallengesCtrl", ['$rootScope','$scope', 'Shared', 'User',
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clone
|
||||||
|
*/
|
||||||
|
$scope.clone = function(challenge) {
|
||||||
|
//We need to clone habits, dailys, todos, and rewards. They each need a new id and entry in the database
|
||||||
|
var clonedTasks = {
|
||||||
|
habit: [],
|
||||||
|
daily: [],
|
||||||
|
todo: [],
|
||||||
|
reward: []
|
||||||
|
};
|
||||||
|
|
||||||
|
function cloneTask(element, index, array) {
|
||||||
|
var task = Shared.taskDefaults({text: element.text, type: element.type});
|
||||||
|
clonedTasks[element.type].push(task);
|
||||||
|
}
|
||||||
|
|
||||||
|
challenge.habits.forEach(cloneTask);
|
||||||
|
challenge.dailys.forEach(cloneTask);
|
||||||
|
challenge.todos.forEach(cloneTask);
|
||||||
|
challenge.rewards.forEach(cloneTask);
|
||||||
|
|
||||||
|
//Use values from inc challenge. The reasons we don't use the whole challenge object is because
|
||||||
|
//Values like timestamp and memebers shouldn't be copied.
|
||||||
|
$scope.obj = $scope.newChallenge = new Challenges.Challenge({
|
||||||
|
name: challenge.name,
|
||||||
|
shortName: challenge.shortName,
|
||||||
|
description: challenge.description,
|
||||||
|
habits: clonedTasks.habit,
|
||||||
|
dailys: clonedTasks.daily,
|
||||||
|
todos: clonedTasks.todo,
|
||||||
|
rewards: clonedTasks.reward,
|
||||||
|
leader: User.user._id,
|
||||||
|
group: challenge.group._id,
|
||||||
|
timestamp: +(new Date),
|
||||||
|
members: [],
|
||||||
|
official: false
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Save
|
* Save
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -25,6 +25,7 @@ script(type='text/ng-template', id='partials/options.social.challenges.detail.ht
|
|||||||
div(bindonce='challenge', ng-if='challenge.leader._id==user._id')
|
div(bindonce='challenge', ng-if='challenge.leader._id==user._id')
|
||||||
div(ng-hide='challenge._locked==false')
|
div(ng-hide='challenge._locked==false')
|
||||||
button.btn.btn-sm.btn-default(ng-click='edit(challenge)')=env.t('edit')
|
button.btn.btn-sm.btn-default(ng-click='edit(challenge)')=env.t('edit')
|
||||||
|
button.btn.btn-sm.btn-default(ng-click='clone(challenge)')=env.t('clone')
|
||||||
button.btn.btn-sm.btn-warning(ng-click='close(challenge, $event)', tooltip=env.t('deleteOrSelect'))=env.t('endChallenge')
|
button.btn.btn-sm.btn-warning(ng-click='close(challenge, $event)', tooltip=env.t('deleteOrSelect'))=env.t('endChallenge')
|
||||||
|
|
||||||
form(ng-show='challenge._locked==false')
|
form(ng-show='challenge._locked==false')
|
||||||
|
|||||||
Reference in New Issue
Block a user