web/data/cubicweb.iprogress.js
author Pierre-Yves David <pierre-yves.david@logilab.fr>
Fri, 22 Mar 2013 18:51:03 +0100
changeset 8763 0144b26e958d
parent 5658 7b9553a9db65
permissions -rw-r--r--
[transaction] handle ``mode`` default value in Transaction The transaction mode is now explicitly passed at creation time and always read from the Transaction object. Note that there is a slight behavior change. The transaction mode is now set at the creation of the transaction. Changes made to the default value have no longer any effect on existing transaction.

function ProgressBar() {
    this.budget = 100;
    this.todo = 100;
    this.done = 100;
    this.color_done = "green";
    this.color_budget = "blue";
    this.color_todo = "#cccccc"; //  grey
    this.height = 16;
    this.middle = this.height / 2;
    this.radius = 4;
}

ProgressBar.prototype.draw_one_rect = function(ctx, pos, color, fill) {
    ctx.beginPath();
    ctx.lineWidth = 1;
    ctx.strokeStyle = color;
    if (fill) {
        ctx.fillStyle = color;
        ctx.fillRect(0, 0, pos, this.middle * 2);
    } else {
        ctx.lineWidth = 2;
        ctx.strokeStyle = "black";
        ctx.moveTo(pos, 0);
        ctx.lineTo(pos, this.middle * 2);
        ctx.stroke();
    }
};

ProgressBar.prototype.draw_one_circ = function(ctx, pos, color) {
    ctx.beginPath();
    ctx.lineWidth = 2;
    ctx.strokeStyle = color;
    ctx.moveTo(0, this.middle);
    ctx.lineTo(pos, this.middle);
    ctx.arc(pos, this.middle, this.radius, 0, Math.PI * 2, true);
    ctx.stroke();
};

ProgressBar.prototype.draw_circ = function(ctx) {
    this.draw_one_circ(ctx, this.budget, this.color_budget);
    this.draw_one_circ(ctx, this.todo, this.color_todo);
    this.draw_one_circ(ctx, this.done, this.color_done);
};

ProgressBar.prototype.draw_rect = function(ctx) {
    this.draw_one_rect(ctx, this.todo, this.color_todo, true);
    this.draw_one_rect(ctx, this.done, this.color_done, true);
    this.draw_one_rect(ctx, this.budget, this.color_budget, false);
};

function draw_progressbar(cid, done, todo, budget, color) {
    var canvas = document.getElementById(cid);
    if (canvas.getContext) {
        var ctx = canvas.getContext("2d");
        var bar = new ProgressBar();
        bar.budget = budget;
        bar.todo = todo;
        bar.done = done;
        bar.color_done = color;
        bar.draw_rect(ctx);
    }
}