Commit f5302cdd authored by Bryce Johnson's avatar Bryce Johnson

Initialize timetracker without mock data.

parent 3d653361
......@@ -2,24 +2,24 @@
//= smart_interval
//= subbable_resource
function getRandomInt(min, max) {
const justReturnZero = Math.random > .9;
return justReturnZero ? 0 : Math.floor(Math.random() * (max - min + 1)) + min;
}
((global) => {
$(() => {
const mockData = gl.generateTimeTrackingMockData('estimate-and-spend');
/* This Vue instance represents what will become the parent instance for the
* sidebar. It will be responsible for managing `issuable` state and propagating
* changes to sidebar components.
*/
const issuableData = JSON.parse(document.getElementById('issuable-time-tracker').getAttribute('issuable'));
issuableData.time_spent = issuableData.time_estimate - 1000;
new Vue({
el: '#issuable-time-tracker',
data: {
time_estimated: mockData.time_estimated,
time_spent: mockData.time_spent,
},
computed: {
fetchIssuable() {
return gl.IssuableResource.get.bind(gl.IssuableResource, { type: 'GET', url: gl.IssuableResource.endpoint });
}
issuable: issuableData,
},
methods: {
initPolling() {
......@@ -32,9 +32,11 @@
});
},
updateState(data) {
data = global.generateTimeTrackingMockData('estimate-and-spend');
this.time_estimated = data.time_estimated;
this.time_spent = data.time_spent;
/* MOCK */
data.time_estimate = getRandomInt(0, 10000)
data.time_spent = getRandomInt(0, 10000);
this.issuable = data;
},
},
created() {
......@@ -209,48 +211,4 @@
},
},
});
/***** Mock Data ******/
global.generateTimeTrackingMockData = generateMockStates;
function generateMockStates(state) {
const configurations = {
'estimate-only': {
time_estimated: generateTimeObj(),
time_spent: null
},
'spent-only': {
time_estimated: null,
time_spent: generateTimeObj()
},
'estimate-and-spend': {
time_estimated: generateTimeObj(),
time_spent: generateTimeObj()
},
'nothing': {
time_estimated: null,
time_spent: null
}
};
return configurations[state];
}
function generateTimeObj(
weeks = getRandomInt(0, 12),
days = getRandomInt(0, 7),
hours = getRandomInt(0, 8),
minutes = getRandomInt(0, 60),
totalMinutes = getRandomInt(0, 25 * 7 * 8 * 60)) {
return {
weeks, days, hours, minutes, totalMinutes
};
}
function getRandomInt(min, max) {
const justReturnZero = Math.random > .5;
return justReturnZero ? 0 : Math.floor(Math.random() * (max - min + 1)) + min;
}
}) (window.gl || (window.gl = {}));
......@@ -73,9 +73,9 @@
= f.hidden_field 'milestone_id', value: issuable.milestone_id, id: nil
= dropdown_tag('Milestone', options: { title: 'Assign milestone', toggle_class: 'js-milestone-select js-extra-options', filter: true, dropdown_class: 'dropdown-menu-selectable', placeholder: 'Search milestones', data: { show_no: true, field_name: "#{issuable.to_ability_name}[milestone_id]", project_id: @project.id, issuable_id: issuable.id, milestones: namespace_project_milestones_path(@project.namespace, @project, :json), ability_name: issuable.to_ability_name, issue_update: issuable_json_path(issuable), use_id: true }})
// TODO: Need to add check for time_estimated - if issuable.has_attribute?(:time_estimated) once hooked up to backend
- if issuable.has_attribute?(:due_date)
#issuable-time-tracker.block
%issuable-time-tracker{ ':time_estimated' => 'time_estimated', ':time_spent' => 'time_spent' }
- if issuable.has_attribute?(:time_estimate)
#issuable-time-tracker.block{ issuable: issuable.to_json() }
%issuable-time-tracker{ ':time_estimate' => 'issuable.time_estimate', ':time_spent' => 'issuable.time_spent' }
- if issuable.has_attribute?(:due_date)
.block.due_date
.sidebar-collapsed-icon
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment