1 -- Stock Rotation Rotas
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`
12 ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
14 -- Stock Rotation Stages
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;
33 -- Stock Rotation Items
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;
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');
59 INSERT IGNORE INTO userflags (bit, flag, flagdesc, defaulton) VALUES
60 (24, 'stockrotation', 'Manage stockrotation operations', 0);
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');
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');