Create
cancel
Showing results for 
Search instead for 
Did you mean: 
Sign up Log in
Celebration

Earn badges and make progress

You're on your way to the next level! Join the Kudos program to earn points and save your progress.

Deleted user Avatar
Deleted user

Level 1: Seed

25 / 150 points

Next: Root

Avatar

1 badge earned

Collect

Participate in fun challenges

Challenges come and go, but your rewards stay with you. Do more to earn more!

Challenges
Coins

Gift kudos to your peers

What goes around comes around! Share the love by gifting kudos to your peers.

Recognition
Ribbon

Rise up in the ranks

Keep earning points to reach the top of the leaderboard. It resets every quarter so you always have a chance!

Leaderboard

Come for the products,
stay for the community

The Atlassian Community can help you and your team get more value out of Atlassian products and practices.

Atlassian Community about banner
4,459,770
Community Members
 
Community Events
176
Community Groups

Can a scripted listener on resolve see work logged during the resolve transition?

So I have a listener that is trying to get the value of the total time spent on an issue, being triggered on the Issue Resolved event.

We have the ability for users to set a worklog on the Issue Resolve screen. Unfortunately when the user adds time in this transition, the listener is not returning the time accurately because it's not taking into account the work log generated during the resolve transition.

I've tried this same kind of thing on a script post-function too, and it also doesn't return the accurate time spent; it ignores the resolve-transition added worklog just like the listener does.

Is there something I'm missing, or is there just no way to get the listener (or post-function) to see this on-resolve worklog?

Thanks!

1 answer

1 accepted

3 votes
Answer accepted

Hi Nick,

I don't know if this helps you but here is a script post-function that shows the worklog added during the transition:

import com.atlassian.jira.issue.ModifiedValue
import com.atlassian.jira.issue.MutableIssue
import com.onresolve.scriptrunner.runner.util.UserMessageUtil
import com.atlassian.jira.issue.fields.WorklogSystemField

Map<String,ModifiedValue> modifiedValues = ((MutableIssue)issue).getModifiedFields()

if (modifiedValues.containsKey("worklog")) {
ModifiedValue worklog = modifiedValues.get("worklog")
WorklogSystemField.WorklogValue worklogSystemField = (WorklogSystemField.WorklogValue)worklog.getNewValue()
UserMessageUtil.success('Added worklog: ' + worklogSystemField.timeLogged())
}

 My Jira version 7.1.2 (Jira Server)

That's exactly what I needed!


Only thing I did was since the .timeLogged() function returns a string, I just wrapped it up inside the JiraDurationUtils .parseDuration() function to give me the seconds value and boom, exactly what I wanted.

Thank you so much!

Suggest an answer

Log in or Sign up to answer
TAGS

Atlassian Community Events