Macro for creating event from a meeting notes page Edited

It would be nice to create events in Team Calendar from within a page in Confluence where you plan your meeting.

To achieve this, create a new macro with this code:

#set ($D='$')

 

<script type="text/javascript">

        $(document).ready(function() {

            $('#submitevent').click(  function () {

                 

                var row = AJS.$('.plugin-tabmeta-details table th:contains("startDate")').parent();

                var startDate =  AJS.$('td', row).text().replace( /(\d+) (\w+) (\d{4})[^d]+/, "$2 $1, $3");

                row = AJS.$('.plugin-tabmeta-details table th:contains("calendar")').parent();

                var calendar =  AJS.$('td', row).text();

                row = AJS.$('.plugin-tabmeta-details table th:contains("startTime")').parent();

                var startTime =  AJS.$('td', row).text();

                row = AJS.$('.plugin-tabmeta-details table th:contains("endTime")').parent();

                var endTime =  AJS.$('td', row).text();

                row = AJS.$('.plugin-tabmeta-details table th:contains("where")').parent();

                var where = AJS.$('td', row).text();

                 

                 

                #set ($persons="")

                #set ($datahtml = $renderContext.getEntity().getBodyAsString())

                #foreach ($stringList in $datahtml.split("ri:userkey=\""))

                    #if ($stringList.matches("\w+\".*"))

                        #set ($userkey=$stringList.substring(0,$stringList.indexOf('"')))

                        #if ($persons.length()>0)

                            #set ($persons=$persons+", ")

                        #end

                        #set ($persons=$persons+"'"+$userkey+"'")

                    #end

                #end

                console.log(calendar+" "+startDate+" "+startTime+" "+endTime+" "+where+" "+$persons);

                 

                 ${D}.ajax({

                    url: 'https://YOURCONFLUENCEURL/rest/calendar-services/1.0/calendar/events.json',    //Your api url

                    type: 'PUT',   //type is any HTTP method

                    data: {

                        originalSubCalendarId:'',

                        originalStartDate:'',

                        subCalendarId:calendar,

                        uid:'',

                        eventType:'other',

                        originalEventType:'',

                        customEventTypeId:'',

                        originalCustomEventTypeId:'',

                        childSubCalendarId:'',

                        what:'Fridays Meeting',

                        person:[$persons],

                        startDate:startDate,

                        startTime:startTime,

                        endDate:startDate,

                        endTime:endTime,

                        allDayEvent:false,

                        freq:'',

                        byday:'',

                        interval:1,

                        until:'',

                        repeatEnds:false,

                        recurrenceId:'',

                        editAllInRecurrenceSeries:false,

                        where:where,

                        url:window.location.href,

                        description:'',

                        userTimeZoneId: 'Asia/Yekaterinburg'

                    },      //Data as js object

                    success: function () {

                        $('.eventcreationresults').html(startDate+" "+startTime+" created!");

                    }

                });

            });

 

              

             

        });

    </script>

<form>

    <div class="eventcreationresults">...</div>

    <input id="submitevent" type="button"  value="Create Event">

</form>

 Second, amend the template of your meeting notes so it has Page Properties with such fields (values are for example):

Набросок[1].png

Also, add the macros created before.

You need to get the correct calendar id. Just click your calendar name and copy the id from URL field of a browser:

Набросок (1).png

 

Now everything should work. Just create a new meeting, insert some values in the Page Properties form, save the page and you will see a button "Create Event". Press it once and check if an event appears in the calendar.

Current limitations:

  • The script doesn't check if the event is already created, nor it updates the created event.
  • If your event starts at 11:00 and ends at 12:00, type 11:00 AM and 12:00 PM, otherwise it would produce an error "The event ends earlier than starts".
  • Macro doesn't report any errors.

 

Feel free to improve the macro, but please copy me with your updates so I could also use them :)

Thank you.

0 comments

Comment

Log in or Sign up to comment
How to earn badges on the Atlassian Community

How to earn badges on the Atlassian Community

Badges are a great way to show off community activity, whether you’re a newbie or a Champion.

Learn more
Community showcase
Asked 11 hours ago in Confluence

What are the resources that you use to learn more about Atlassian Products?

I am gathering information about resources available for Atlassian product knowledge transferring for a presentation in our local Atlassian User Group. I want to group them in four categories From ...

59 views 3 4
View question

Atlassian User Groups

Connect with like-minded Atlassian users at free events near you!

Find a group

Connect with like-minded Atlassian users at free events near you!

Find my local user group

Unfortunately there are no AUG chapters near you at the moment.

Start an AUG

You're one step closer to meeting fellow Atlassian users at your local meet up. Learn more about AUGs

Groups near you