blob: 2595869e9aa46018d7f425036a417b53d29704d5 [file] [log] [blame]
Anand Doshieaaf6512012-02-24 15:29:07 +05301wn.provide('erpnext.desktop');
2
3erpnext.desktop.gradient = "<style>\
4 .case-%(name)s {\
5 background: %(start)s; /* Old browsers */\
6 background: -moz-radial-gradient(center, ellipse cover, %(start)s 0%, %(middle)s 44%, %(end)s 100%); /* FF3.6+ */\
7 background: -webkit-gradient(radial, center center, 0px, center center, 100%, color-stop(0%,%(start)s), color-stop(44%,%(middle)s), color-stop(100%,%(end)s)); /* Chrome,Safari4+ */\
8 background: -webkit-radial-gradient(center, ellipse cover, %(start)s 0%,%(middle)s 44%,%(end)s 100%); /* Chrome10+,Safari5.1+ */\
9 background: -o-radial-gradient(center, ellipse cover, %(start)s 0%,%(middle)s 44%,%(end)s 100%); /* Opera 12+ */\
10 background: -ms-radial-gradient(center, ellipse cover, %(start)s 0%,%(middle)s 44%,%(end)s 100%); /* IE10+ */\
11 background: radial-gradient(center, ellipse cover, %(start)s 0%,%(middle)s 44%,%(end)s 100%); /* W3C */\
12 }\
13 </style>"
14
15erpnext.desktop.refresh = function() {
16 erpnext.desktop.add_classes();
17 erpnext.desktop.render();
18}
19
20erpnext.desktop.add_classes = function() {
21 var classes = [
22 { name: 'red', start: '#A90329', middle: '#8F0222', end: '#6D0019' },
23 { name: 'brown', start: '#723e02', middle: '#633501', end: '#4a2700' },
24 { name: 'green', start: '#4b5602', middle: '#3f4901', end: '#313800' },
25 { name: 'blue', start: '#026584', middle: '#025770', end: '#004256' },
26 { name: 'yellow', start: '#be7902', middle: '#a66a02', end: '#865500' },
27 { name: 'purple', start: '#4d017d', middle: '#410169', end: '#310050' },
28 { name: 'ocean', start: '#02a47e', middle: '#018d6c', end: '#006a51' },
29 { name: 'pink', start: '#a40281', middle: '#8d016e', end: '#6a0053' },
30 { name: 'grey', start: '#545454', middle: '#484848', end: '#363636' },
31 { name: 'dark-red', start: '#68021a', middle: '#590116', end: '#440010' },
32 { name: 'leaf-green', start: '#b0a400', middle: '#968c00', end: '#726a00' },
33 { name: 'dark-blue', start: '#023bae', middle: '#013295', end: '#002672' },
34 { name: 'bright-green', start: '#03ad1f', middle: '#02941a', end: '#007213' },
35 { name: 'bright-yellow', start: '#ffd65e', middle: '#febf04', end: '#ed9017' },
36 ];
37 $.each(classes, function(i, v) {
38 $(repl(erpnext.desktop.gradient, v)).appendTo('head');
39 });
40}
41
42erpnext.desktop.render = function() {
43 var icons = [
44 { gradient: 'brown', sprite: 'feed', label: 'Activity', link: '#!Event Updates' },
45 { gradient: 'blue', sprite: 'account', label: 'Accounts', link: '#!accounts-home' },
46 { gradient: 'green', sprite: 'selling', label: 'Selling', link: '#!selling-home' },
47 { gradient: 'yellow', sprite: 'stock', label: 'Stock', link: '#!stock-home' },
48 { gradient: 'red', sprite: 'buying', label: 'Buying', link: '#!buying-home' },
49 { gradient: 'purple', sprite: 'support', label: 'Support', link: '#!support-home' },
50 { gradient: 'ocean', sprite: 'hr', label: 'Human<br />Resources', link: '#!hr-home' },
51 { gradient: 'red', sprite: 'project', label: 'Projects', link: '#!projects-home' },
52 { gradient: 'dark-red', sprite: 'production', label: 'Production', link: '#!production-home' },
53 { gradient: 'leaf-green', sprite: 'website', label: 'Website', link: '#!website-home' },
54 { gradient: 'grey', sprite: 'setting', label: 'Settings', link: '#!Setup' },
55 { gradient: 'bright-green', sprite: 'dashboard', label: 'Dashboard', link: '#!dashboard' },
56 //{ gradient: 'dark-blue', sprite: 'report', label: 'Report' },
57 { gradient: 'pink', sprite: 'messages', label: 'Messages', link: '#!messages' },
58 { gradient: 'bright-yellow', sprite: 'todo', label: 'To Do', link: '#!todo' },
59 { gradient: 'red', sprite: 'calendar', label: 'Calendar', link: '#!calendar' },
60 { gradient: 'red', sprite: 'kb', label: 'Knowledge<br />Base', link: '#!questions' },
61 ]
62
63 $.each(icons, function(i, v) {
64 var icon_case = $('#icon-grid').append(repl('\
65 <div class="case-wrapper"><a href=%(link)s>\
66 <div class="case-border case-%(gradient)s">\
67 <div class="sprite-image sprite-%(sprite)s"></div>\
68 </div></a>\
69 <div class="case-label">%(label)s</div>\
70 </div>', v));
71 });
72
73}
74
75pscript.onload_desktop = function() {
76 // load desktop
77 erpnext.desktop.refresh();
78}
79