Bug 11897: Add Stock Rotation atomic update schema.
[koha.git] / installer / data / mysql / atomicupdate / stockrot_tables.sql
1 -- Stock Rotation Rotas
2
3 CREATE TABLE IF NOT EXISTS stockrotationrotas (
4     rota_id int(11) auto_increment,          -- Stockrotation rota ID
5     title varchar(100) NOT NULL,            -- Title for this rota
6     description text NOT NULL default '',   -- Description for this rota
7     cyclical tinyint(1) NOT NULL default 0, -- Should items on this rota keep cycling?
8     active tinyint(1) NOT NULL default 0,   -- Is this rota currently active?
9     PRIMARY KEY (`rota_id`),
10     CONSTRAINT `stockrotationrotas_title`
11       UNIQUE (`title`)
12 ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
13
14 -- Stock Rotation Stages
15
16 CREATE TABLE IF NOT EXISTS stockrotationstages (
17     stage_id int(11) auto_increment,     -- Unique stage ID
18     position int(11) NOT NULL,           -- The position of this stage within its rota
19     rota_id int(11) NOT NULL,            -- The rota this stage belongs to
20     branchcode_id varchar(10) NOT NULL,  -- Branch this stage relates to
21     duration int(11) NOT NULL default 4, -- The number of days items shoud occupy this stage
22     PRIMARY KEY (`stage_id`),
23     CONSTRAINT `stockrotationstages_rifk`
24       FOREIGN KEY (`rota_id`)
25       REFERENCES `stockrotationrotas` (`rota_id`)
26       ON UPDATE CASCADE ON DELETE CASCADE,
27     CONSTRAINT `stockrotationstages_bifk`
28       FOREIGN KEY (`branchcode_id`)
29       REFERENCES `branches` (`branchcode`)
30       ON UPDATE CASCADE ON DELETE CASCADE
31 ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
32
33 -- Stock Rotation Items
34
35 CREATE TABLE IF NOT EXISTS stockrotationitems (
36     itemnumber_id int(11) NOT NULL,         -- Itemnumber to link to a stage & rota
37     stage_id int(11) NOT NULL,              -- stage ID to link the item to
38     indemand tinyint(1) NOT NULL default 0, -- Should this item be skipped for rotation?
39     fresh tinyint(1) NOT NULL default 0,    -- Flag showing item is only just added to rota
40     PRIMARY KEY (itemnumber_id),
41     CONSTRAINT `stockrotationitems_iifk`
42       FOREIGN KEY (`itemnumber_id`)
43       REFERENCES `items` (`itemnumber`)
44       ON UPDATE CASCADE ON DELETE CASCADE,
45     CONSTRAINT `stockrotationitems_sifk`
46       FOREIGN KEY (`stage_id`)
47       REFERENCES `stockrotationstages` (`stage_id`)
48       ON UPDATE CASCADE ON DELETE CASCADE
49 ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
50
51 -- System preferences
52
53 INSERT IGNORE INTO systempreferences (variable,value,explanation,options,type) VALUES
54        ('StockRotation','0','If ON, enables the stock rotation module','','YesNo'),
55        ('RotationPreventTransfers','0','If ON, prevent any transfers for items on stock rotation rotas, except for stock rotation transfers','','YesNo');
56
57 -- Permissions
58
59 INSERT IGNORE INTO userflags (bit, flag, flagdesc, defaulton) VALUES
60        (24, 'stockrotation', 'Manage stockrotation operations', 0);
61
62 INSERT IGNORE INTO permissions (module_bit, code, description) VALUES
63        (24, 'manage_rotas', 'Create, edit and delete rotas'),
64        (24, 'manage_rota_items', 'Add and remove items from rotas');
65
66 -- Notices
67
68 INSERT IGNORE INTO letter (module, code, branchcode, name, is_html, title, content, message_transport_type) VALUES
69        ('circulation', 'SR_SLIP', '', 'Stock Rotation Slip', 0, 'Stockrotation Report', 'Stockrotation report for [% branch.name %]:\r\n\r\n[% IF branch.items.size %][% branch.items.size %] items to be processed for this branch.\r\n[% ELSE %]No items to be processed for this branch\r\n[% END %][% FOREACH item IN branch.items %][% IF item.reason ne \'in-demand\' %]Title: [% item.title %]\r\nAuthor: [% item.author %]\r\nCallnumber: [% item.callnumber %]\r\nLocation: [% item.location %]\r\nBarcode: [% item.barcode %]\r\nOn loan?: [% item.onloan %]\r\nStatus: [% item.reason %]\r\nCurrent Library: [% item.branch.branchname %] [% item.branch.branchcode %]\r\n\r\n[% END %][% END %]', 'email');