IDEMPIERE-4894 OSGi Interface to support custom header and footer (#804)

* IDEMPIERE-4894 OSGi Interface to support custom header and footer

* IDEMPIERE-4894 OSGi Interface to support custom header and footer

incorporate migration script fix from Carlos
This commit is contained in:
hengsin 2021-07-30 19:53:28 +08:00 committed by GitHub
parent 3c8e05c9d6
commit 1fb4067c01
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
12 changed files with 1094 additions and 139 deletions

View File

@ -0,0 +1,249 @@
SET SQLBLANKLINES ON
SET DEFINE OFF
-- IDEMPIERE-4894 OSGi Interface to support custom header and footer
INSERT INTO AD_Table (AccessLevel,AD_Client_ID,AD_Org_ID,AD_Table_ID,AD_Table_UU,Created,CreatedBy,Description,EntityType,IsActive,IsCentrallyMaintained,IsChangeLog,IsDeleteable,IsHighVolume,IsSecurityEnabled,IsView,LoadSeq,Name,Processing,ReplicationType,TableName,Updated,UpdatedBy) VALUES ('4',0,0,200240,'4e785f3f-dce9-4f27-900a-504122d447d0',TO_DATE('2021-07-28 17:00:08','YYYY-MM-DD HH24:MI:SS'),100,NULL,'D','Y','Y','Y','Y','N','N','N',145,'Print Header/Footer','N','L','AD_PrintHeaderFooter',TO_DATE('2021-07-28 17:00:08','YYYY-MM-DD HH24:MI:SS'),100)
;
-- July 28, 2021 5:00:11 PM SGT
INSERT INTO AD_Sequence (AD_Client_ID,AD_Org_ID,AD_Sequence_ID,AD_Sequence_UU,Created,CreatedBy,CurrentNext,CurrentNextSys,Description,IncrementNo,IsActive,IsAudited,IsAutoSequence,IsTableID,Name,StartNewYear,StartNo,Updated,UpdatedBy) VALUES (0,0,200304,'55b3e131-60d2-46fa-9665-ba039f2f37ee',TO_DATE('2021-07-28 17:00:10','YYYY-MM-DD HH24:MI:SS'),100,1000000,200000,'Table AD_PrintHeaderFooter',1,'Y','N','Y','Y','AD_PrintHeaderFooter','N',1000000,TO_DATE('2021-07-28 17:00:10','YYYY-MM-DD HH24:MI:SS'),100)
;
-- July 28, 2021 5:00:32 PM SGT
INSERT INTO AD_TreeNode (AD_Client_ID,AD_Org_ID, IsActive,Created,CreatedBy,Updated,UpdatedBy, AD_Tree_ID, Node_ID, Parent_ID, SeqNo, AD_TreeNode_UU) SELECT t.AD_Client_ID, 0, 'Y', SysDate, 100, SysDate, 100,t.AD_Tree_ID, 200003, 0, 999, Generate_UUID() FROM AD_Tree t WHERE t.AD_Client_ID=0 AND t.IsActive='Y' AND t.IsAllNodes='Y' AND t.TreeType='TL' AND t.AD_Table_ID=282 AND NOT EXISTS (SELECT * FROM AD_TreeNode e WHERE e.AD_Tree_ID=t.AD_Tree_ID AND Node_ID=200003)
;
-- July 28, 2021 5:00:34 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,DefaultValue,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,FKConstraintType,AD_Element_ID,AD_Val_Rule_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213508,'N',1,'Y','N','N','N',22,'N','N','N','N','d49721fe-2f15-43e9-ba7a-b7472cc06304',TO_DATE('2021-07-28 17:00:32','YYYY-MM-DD HH24:MI:SS'),'N','AD_Client_ID','Client/Tenant for this installation.','@#AD_Client_ID@','A Client is a company or a legal entity. You cannot share data between Clients. Tenant is a synonym for Client.','Client','N','Y',100,100,'N',0,0,TO_DATE('2021-07-28 17:00:32','YYYY-MM-DD HH24:MI:SS'),'N','D','N','D',102,129,200240,19,'N')
;
-- July 28, 2021 5:00:37 PM SGT
INSERT INTO AD_Element (AD_Element_ID,ColumnName,Updated,Name,PrintName,AD_Element_UU,IsActive,Created,AD_Org_ID,CreatedBy,UpdatedBy,AD_Client_ID,EntityType) VALUES (203210,'AD_PrintHeaderFooter_ID',TO_DATE('2021-07-28 17:00:35','YYYY-MM-DD HH24:MI:SS'),'Print Header/Footer','Print Header/Footer','1c0cdce7-c3ca-4cdd-8ce2-154f0bf3c826','Y',TO_DATE('2021-07-28 17:00:35','YYYY-MM-DD HH24:MI:SS'),0,100,100,0,'D')
;
-- July 28, 2021 5:00:38 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,AD_Element_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213509,'N',1,'Y','N','N','N',22,'N','Y','N','N','2ab090db-0460-49a6-b263-ab555919fac7',TO_DATE('2021-07-28 17:00:35','YYYY-MM-DD HH24:MI:SS'),'N','AD_PrintHeaderFooter_ID','Print Header/Footer','N','Y',100,100,'N',0,0,TO_DATE('2021-07-28 17:00:35','YYYY-MM-DD HH24:MI:SS'),'N','D','N',203210,200240,13,'N')
;
-- July 28, 2021 5:00:40 PM SGT
INSERT INTO AD_Element (AD_Element_ID,ColumnName,Updated,Name,PrintName,AD_Element_UU,IsActive,Created,AD_Org_ID,CreatedBy,UpdatedBy,AD_Client_ID,EntityType) VALUES (203211,'AD_PrintHeaderFooter_UU',TO_DATE('2021-07-28 17:00:38','YYYY-MM-DD HH24:MI:SS'),'AD_PrintHeaderFooter_UU','AD_PrintHeaderFooter_UU','b38888ed-e649-4d99-a6b4-206305fba4af','Y',TO_DATE('2021-07-28 17:00:38','YYYY-MM-DD HH24:MI:SS'),0,100,100,0,'D')
;
-- July 28, 2021 5:00:42 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,AD_Element_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213510,'N',1.00,'N','N','N','N',36,'N','N','N','Y','96f6a17f-1cbb-46a5-8071-a416efa85693',TO_DATE('2021-07-28 17:00:38','YYYY-MM-DD HH24:MI:SS'),'Y','AD_PrintHeaderFooter_UU','AD_PrintHeaderFooter_UU','N','Y',100,100,'N',0,0,TO_DATE('2021-07-28 17:00:38','YYYY-MM-DD HH24:MI:SS'),'N','D','N',203211,200240,10,'N')
;
-- July 28, 2021 5:00:43 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,FKConstraintType,AD_Element_ID,AD_Reference_Value_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213511,'N',1,'N','N','N','N',6,'N','N','N','Y','b9230734-b179-4c64-9cf8-ecec62fc6e49',TO_DATE('2021-07-28 17:00:42','YYYY-MM-DD HH24:MI:SS'),'Y','AD_Language','Language for this entity','The Language identifies the language to use for display and formatting','Language','Y','Y',100,100,'N',0,0,TO_DATE('2021-07-28 17:00:42','YYYY-MM-DD HH24:MI:SS'),'N','D','N','N',109,106,200240,18,'N')
;
-- July 28, 2021 5:00:46 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,DefaultValue,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,FKConstraintType,AD_Element_ID,AD_Val_Rule_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213512,'N',1,'Y','N','N','N',22,'N','N','N','N','50c1a0f8-dde9-4557-b4a3-5524424eafe5',TO_DATE('2021-07-28 17:00:43','YYYY-MM-DD HH24:MI:SS'),'N','AD_Org_ID','Organizational entity within client','@#AD_Org_ID@','An organization is a unit of your client or legal entity - examples are store, department. You can share data between organizations.','Organization','N','Y',100,100,'N',0,0,TO_DATE('2021-07-28 17:00:43','YYYY-MM-DD HH24:MI:SS'),'N','D','N','D',113,104,200240,19,'N')
;
-- July 28, 2021 5:00:48 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,AD_Element_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213513,'N',1,'N','N','N','N',2000,'N','N','N','Y','811cd8be-9f60-4d1b-9f5b-3eb514aa3148',TO_DATE('2021-07-28 17:00:46','YYYY-MM-DD HH24:MI:SS'),'Y','Code','Validation Code','The Validation Code displays the date, time and message of the error.','Validation code','Y','Y',100,100,'N',0,0,TO_DATE('2021-07-28 17:00:46','YYYY-MM-DD HH24:MI:SS'),'N','D','N',227,200240,10,'N')
;
-- July 28, 2021 5:00:49 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,DefaultValue,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,AD_Element_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213514,'N',1,'Y','N','N','N',7,'N','N','N','N','0666c09c-9082-4a51-b936-9cf95a76c171',TO_DATE('2021-07-28 17:00:48','YYYY-MM-DD HH24:MI:SS'),'N','Created','Date this record was created','SYSDATE','The Created field indicates the date that this record was created.','Created','N','Y',100,100,'N',0,0,TO_DATE('2021-07-28 17:00:48','YYYY-MM-DD HH24:MI:SS'),'N','D','N',245,200240,16,'N')
;
-- July 28, 2021 5:00:50 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,FKConstraintType,AD_Element_ID,AD_Reference_Value_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213515,'N',1,'Y','N','N','N',22,'N','N','N','N','6754886f-9531-4435-9881-6aeb117c5d9f',TO_DATE('2021-07-28 17:00:49','YYYY-MM-DD HH24:MI:SS'),'N','CreatedBy','User who created this records','The Created By field indicates the user who created this record.','Created By','N','Y',100,100,'N',0,0,TO_DATE('2021-07-28 17:00:49','YYYY-MM-DD HH24:MI:SS'),'N','D','N','D',246,110,200240,18,'N')
;
-- July 28, 2021 5:00:52 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,DefaultValue,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,AD_Element_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213516,'N',1,'Y','N','N','N',1,'N','N','N','Y','11b3d43d-e42d-4212-b5ff-be3f4344b044',TO_DATE('2021-07-28 17:00:50','YYYY-MM-DD HH24:MI:SS'),'Y','IsActive','The record is active in the system','Y','There are two methods of making records unavailable in the system: One is to delete the record, the other is to de-activate the record. A de-activated record is not available for selection, but available for reports.
There are two reasons for de-activating and not deleting records:
(1) The system requires the record for audit purposes.
(2) The record is referenced by other records. E.g., you cannot delete a Business Partner, if there are invoices for this partner record existing. You de-activate the Business Partner and prevent that this record is used for future entries.','Active','N','Y',100,100,'N',0,0,TO_DATE('2021-07-28 17:00:50','YYYY-MM-DD HH24:MI:SS'),'N','D','N',348,200240,20,'N')
;
-- July 28, 2021 5:00:52 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,SeqNo,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,AD_Element_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213517,'N',1,'Y','N','Y',1,'N',60,'Y','N','N','Y','0d3ae0bf-64e9-4aef-a657-d0ccc402bf30',TO_DATE('2021-07-28 17:00:52','YYYY-MM-DD HH24:MI:SS'),'Y','Name','Alphanumeric identifier of the entity','The name of an entity (record) is used as an default search option in addition to the search key. The name is up to 60 characters in length.','Name','Y','Y',100,100,'N',0,0,TO_DATE('2021-07-28 17:00:52','YYYY-MM-DD HH24:MI:SS'),'N','D','N',469,200240,10,'N')
;
-- July 28, 2021 5:00:53 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,DefaultValue,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,AD_Element_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213518,'N',1,'Y','N','N','N',7,'N','N','N','N','07ea1bc7-a0b4-4bc5-952a-35cdb8da475f',TO_DATE('2021-07-28 17:00:52','YYYY-MM-DD HH24:MI:SS'),'N','Updated','Date this record was updated','SYSDATE','The Updated field indicates the date that this record was updated.','Updated','N','Y',100,100,'N',0,0,TO_DATE('2021-07-28 17:00:52','YYYY-MM-DD HH24:MI:SS'),'N','D','N',607,200240,16,'N')
;
-- July 28, 2021 5:01:02 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,FKConstraintType,AD_Element_ID,AD_Reference_Value_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213519,'N',1,'Y','N','N','N',22,'N','N','N','N','29ac01ef-6553-4f9a-853d-40423438a032',TO_DATE('2021-07-28 17:00:53','YYYY-MM-DD HH24:MI:SS'),'N','UpdatedBy','User who updated this records','The Updated By field indicates the user who updated this record.','Updated By','N','Y',100,100,'N',0,0,TO_DATE('2021-07-28 17:00:53','YYYY-MM-DD HH24:MI:SS'),'N','D','N','D',608,110,200240,18,'N')
;
-- July 28, 2021 5:01:27 PM SGT
DELETE FROM AD_Column_Trl WHERE AD_Column_ID=213511
;
-- July 28, 2021 5:01:27 PM SGT
DELETE FROM AD_Column WHERE AD_Column_ID=213511
;
-- July 28, 2021 5:01:29 PM SGT
DELETE FROM AD_Column_Trl WHERE AD_Column_ID=213513
;
-- July 28, 2021 5:01:29 PM SGT
DELETE FROM AD_Column WHERE AD_Column_ID=213513
;
-- July 28, 2021 5:03:53 PM SGT
INSERT INTO AD_Column (AD_Column_ID,SeqNoSelection,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,SeqNo,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,AD_Element_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213520,0,'N',0,'N','N','N',0,'N',255,'Y','N','N','Y','3e4f5498-0035-486a-b14a-846b501ddb40',TO_DATE('2021-07-28 17:03:52','YYYY-MM-DD HH24:MI:SS'),'Y','SourceClassName','Source Class Name','Source Class','Y','Y',100,100,'N',0,0,TO_DATE('2021-07-28 17:03:52','YYYY-MM-DD HH24:MI:SS'),'N','U','N',2942,200240,10,'N')
;
-- July 28, 2021 5:03:56 PM SGT
UPDATE AD_Column SET EntityType='D',Updated=TO_DATE('2021-07-28 17:03:56','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Column_ID=213520
;
-- July 28, 2021 5:04:16 PM SGT
INSERT INTO AD_TreeNode (AD_Client_ID,AD_Org_ID, IsActive,Created,CreatedBy,Updated,UpdatedBy, AD_Tree_ID, Node_ID, Parent_ID, SeqNo, AD_TreeNode_UU) SELECT t.AD_Client_ID, 0, 'Y', SysDate, 100, SysDate, 100,t.AD_Tree_ID, 200004, 0, 999, Generate_UUID() FROM AD_Tree t WHERE t.AD_Client_ID=0 AND t.IsActive='Y' AND t.IsAllNodes='Y' AND t.TreeType='TL' AND t.AD_Table_ID=282 AND NOT EXISTS (SELECT * FROM AD_TreeNode e WHERE e.AD_Tree_ID=t.AD_Tree_ID AND Node_ID=200004)
;
-- July 28, 2021 5:04:17 PM SGT
CREATE TABLE AD_PrintHeaderFooter (AD_Client_ID NUMBER(10) NOT NULL, AD_Org_ID NUMBER(10) NOT NULL, AD_PrintHeaderFooter_ID NUMBER(10) NOT NULL, AD_PrintHeaderFooter_UU VARCHAR2(36 CHAR) DEFAULT NULL , Created DATE DEFAULT SYSDATE NOT NULL, CreatedBy NUMBER(10) NOT NULL, IsActive CHAR(1) DEFAULT 'Y' CHECK (IsActive IN ('Y','N')) NOT NULL, Name VARCHAR2(60 CHAR) NOT NULL, SourceClassName VARCHAR2(255 CHAR) DEFAULT NULL , Updated DATE DEFAULT SYSDATE NOT NULL, UpdatedBy NUMBER(10) NOT NULL, CONSTRAINT AD_PrintHeaderFooter_Key PRIMARY KEY (AD_PrintHeaderFooter_ID), CONSTRAINT AD_PrintHeaderFooter_UU_idx UNIQUE (AD_PrintHeaderFooter_UU))
;
-- July 28, 2021 5:04:58 PM SGT
INSERT INTO AD_Window (WindowType,Help,IsSOTrx,IsDefault,IsBetaFunctionality,Processing,AD_Org_ID,Name,Description,AD_Window_ID,AD_Window_UU,IsActive,AD_Client_ID,Updated,CreatedBy,UpdatedBy,EntityType,Created) VALUES ('M',NULL,'Y','N','N','N',0,'Print Header/Footer','Maintain Print Header/Footer',200100,'681b8621-d60e-4d33-9c10-ca6effe4b23e','Y',0,TO_DATE('2021-07-28 17:04:57','YYYY-MM-DD HH24:MI:SS'),100,100,'D',TO_DATE('2021-07-28 17:04:57','YYYY-MM-DD HH24:MI:SS'))
;
-- July 28, 2021 5:06:41 PM SGT
INSERT INTO AD_Tab (AD_Client_ID,AD_Org_ID,AD_Tab_ID,AD_Table_ID,AD_Tab_UU,AD_Window_ID,Created,CreatedBy,EntityType,HasTree,ImportFields,IsActive,IsAdvancedTab,IsInfoTab,IsInsertRecord,IsReadOnly,IsSingleRow,IsSortTab,IsTranslationTab,Name,Processing,SeqNo,TabLevel,TreeDisplayedOn,Updated,UpdatedBy) VALUES (0,0,200249,200240,'b3beffb9-ab5f-4d40-9a6b-2f849306e9e6',200100,TO_DATE('2021-07-28 17:06:39','YYYY-MM-DD HH24:MI:SS'),100,'D','N','N','Y','N','N','Y','N','Y','N','N','Print Header/Footer','N',10,0,'M',TO_DATE('2021-07-28 17:06:39','YYYY-MM-DD HH24:MI:SS'),100)
;
-- July 28, 2021 5:06:57 PM SGT
INSERT INTO AD_TreeNode (AD_Client_ID,AD_Org_ID, IsActive,Created,CreatedBy,Updated,UpdatedBy, AD_Tree_ID, Node_ID, Parent_ID, SeqNo, AD_TreeNode_UU) SELECT t.AD_Client_ID, 0, 'Y', SysDate, 100, SysDate, 100,t.AD_Tree_ID, 200005, 0, 999, Generate_UUID() FROM AD_Tree t WHERE t.AD_Client_ID=0 AND t.IsActive='Y' AND t.IsAllNodes='Y' AND t.TreeType='TL' AND t.AD_Table_ID=282 AND NOT EXISTS (SELECT * FROM AD_TreeNode e WHERE e.AD_Tree_ID=t.AD_Tree_ID AND Node_ID=200005)
;
-- July 28, 2021 5:07:00 PM SGT
INSERT INTO AD_Field (AD_Field_ID,IsEncrypted,DisplayLength,IsSameLine,IsHeading,SeqNo,IsCentrallyMaintained,IsReadOnly,Help,AD_Org_ID,Updated,Description,Name,AD_Field_UU,IsDisplayed,IsFieldOnly,CreatedBy,UpdatedBy,IsActive,IsDisplayedGrid,SeqNoGrid,AD_Client_ID,Created,ColumnSpan,AD_Column_ID,EntityType,AD_Tab_ID) VALUES (205577,'N',22,'N','N',10,'Y','N','A Client is a company or a legal entity. You cannot share data between Clients. Tenant is a synonym for Client.',0,TO_DATE('2021-07-28 17:06:58','YYYY-MM-DD HH24:MI:SS'),'Client/Tenant for this installation.','Client','4bc05f5f-d904-4027-a467-508d13ba967a','Y','N',100,100,'Y','Y',10,0,TO_DATE('2021-07-28 17:06:58','YYYY-MM-DD HH24:MI:SS'),2,213508,'D',200249)
;
-- July 28, 2021 5:07:03 PM SGT
INSERT INTO AD_Field (AD_Field_ID,IsEncrypted,DisplayLength,IsSameLine,IsHeading,SeqNo,IsCentrallyMaintained,IsReadOnly,Help,AD_Org_ID,Updated,Description,Name,AD_Field_UU,IsDisplayed,IsFieldOnly,IsAllowCopy,CreatedBy,UpdatedBy,IsActive,IsDisplayedGrid,SeqNoGrid,XPosition,AD_Client_ID,Created,ColumnSpan,AD_Column_ID,EntityType,AD_Tab_ID) VALUES (205578,'N',22,'N','N',20,'Y','N','An organization is a unit of your client or legal entity - examples are store, department. You can share data between organizations.',0,TO_DATE('2021-07-28 17:07:00','YYYY-MM-DD HH24:MI:SS'),'Organizational entity within client','Organization','051d2a8a-4dbd-4706-9f80-897e5b3986c4','Y','N','Y',100,100,'Y','Y',20,4,0,TO_DATE('2021-07-28 17:07:00','YYYY-MM-DD HH24:MI:SS'),2,213512,'D',200249)
;
-- July 28, 2021 5:07:05 PM SGT
INSERT INTO AD_Field (AD_Field_ID,IsEncrypted,DisplayLength,IsSameLine,IsHeading,SeqNo,IsCentrallyMaintained,IsReadOnly,Help,AD_Org_ID,Updated,Description,Name,AD_Field_UU,IsDisplayed,IsFieldOnly,CreatedBy,UpdatedBy,IsActive,IsDisplayedGrid,SeqNoGrid,AD_Client_ID,Created,ColumnSpan,AD_Column_ID,EntityType,AD_Tab_ID) VALUES (205579,'N',60,'N','N',30,'Y','N','The name of an entity (record) is used as an default search option in addition to the search key. The name is up to 60 characters in length.',0,TO_DATE('2021-07-28 17:07:03','YYYY-MM-DD HH24:MI:SS'),'Alphanumeric identifier of the entity','Name','acc95b14-bff5-4d21-8b2d-c3a07d008d4e','Y','N',100,100,'Y','Y',30,0,TO_DATE('2021-07-28 17:07:03','YYYY-MM-DD HH24:MI:SS'),5,213517,'D',200249)
;
-- July 28, 2021 5:07:06 PM SGT
INSERT INTO AD_Field (AD_Field_ID,IsEncrypted,DisplayLength,IsSameLine,IsHeading,IsCentrallyMaintained,IsReadOnly,AD_Org_ID,Updated,Name,AD_Field_UU,IsDisplayed,IsFieldOnly,CreatedBy,UpdatedBy,IsActive,IsDisplayedGrid,AD_Client_ID,Created,ColumnSpan,AD_Column_ID,EntityType,AD_Tab_ID) VALUES (205580,'N',22,'N','N','Y','N',0,TO_DATE('2021-07-28 17:07:05','YYYY-MM-DD HH24:MI:SS'),'Print Header/Footer','636434ea-cb1a-4f20-8ca7-34c1fcf6a4ff','N','N',100,100,'Y','N',0,TO_DATE('2021-07-28 17:07:05','YYYY-MM-DD HH24:MI:SS'),2,213509,'D',200249)
;
-- July 28, 2021 5:07:08 PM SGT
INSERT INTO AD_Field (AD_Field_ID,IsEncrypted,DisplayLength,IsSameLine,IsHeading,IsCentrallyMaintained,IsReadOnly,AD_Org_ID,Updated,Name,AD_Field_UU,IsDisplayed,IsFieldOnly,CreatedBy,UpdatedBy,IsActive,IsDisplayedGrid,AD_Client_ID,Created,ColumnSpan,AD_Column_ID,EntityType,AD_Tab_ID) VALUES (205581,'N',36,'N','N','Y','N',0,TO_DATE('2021-07-28 17:07:06','YYYY-MM-DD HH24:MI:SS'),'AD_PrintHeaderFooter_UU','0374e4a2-7b93-40d8-9928-f883f54803ad','N','N',100,100,'Y','N',0,TO_DATE('2021-07-28 17:07:06','YYYY-MM-DD HH24:MI:SS'),2,213510,'D',200249)
;
-- July 28, 2021 5:07:09 PM SGT
INSERT INTO AD_Field (AD_Field_ID,IsEncrypted,DisplayLength,IsSameLine,IsHeading,SeqNo,IsCentrallyMaintained,IsReadOnly,AD_Org_ID,Updated,Description,Name,AD_Field_UU,IsDisplayed,IsFieldOnly,CreatedBy,UpdatedBy,IsActive,IsDisplayedGrid,SeqNoGrid,AD_Client_ID,Created,ColumnSpan,AD_Column_ID,EntityType,AD_Tab_ID) VALUES (205582,'N',255,'N','N',40,'Y','N',0,TO_DATE('2021-07-28 17:07:08','YYYY-MM-DD HH24:MI:SS'),'Source Class Name','Source Class','246e8579-9378-45c8-8c5e-dbc77f29abc2','Y','N',100,100,'Y','Y',40,0,TO_DATE('2021-07-28 17:07:08','YYYY-MM-DD HH24:MI:SS'),5,213520,'D',200249)
;
-- July 28, 2021 5:07:10 PM SGT
INSERT INTO AD_Field (AD_Field_ID,IsEncrypted,DisplayLength,IsSameLine,IsHeading,SeqNo,IsCentrallyMaintained,IsReadOnly,Help,AD_Org_ID,Updated,Description,Name,AD_Field_UU,IsDisplayed,IsFieldOnly,CreatedBy,UpdatedBy,IsActive,IsDisplayedGrid,SeqNoGrid,XPosition,AD_Client_ID,Created,ColumnSpan,AD_Column_ID,EntityType,AD_Tab_ID) VALUES (205583,'N',1,'N','N',50,'Y','N','There are two methods of making records unavailable in the system: One is to delete the record, the other is to de-activate the record. A de-activated record is not available for selection, but available for reports.
There are two reasons for de-activating and not deleting records:
(1) The system requires the record for audit purposes.
(2) The record is referenced by other records. E.g., you cannot delete a Business Partner, if there are invoices for this partner record existing. You de-activate the Business Partner and prevent that this record is used for future entries.',0,TO_DATE('2021-07-28 17:07:09','YYYY-MM-DD HH24:MI:SS'),'The record is active in the system','Active','f1bbff39-345a-4511-9501-5303b4fada21','Y','N',100,100,'Y','Y',50,2,0,TO_DATE('2021-07-28 17:07:09','YYYY-MM-DD HH24:MI:SS'),2,213516,'D',200249)
;
-- July 28, 2021 5:09:08 PM SGT
INSERT INTO AD_Menu (AD_Menu_ID,IsSummary,AD_Menu_UU,IsSOTrx,IsReadOnly,IsCentrallyMaintained,Name,Description,Action,IsActive,CreatedBy,AD_Org_ID,AD_Client_ID,Created,Updated,UpdatedBy,EntityType,AD_Window_ID) VALUES (200156,'N','4544341f-cd36-4d72-8484-2f5908a9dfd9','Y','N','Y','Print Header/Footer','Maintain Print Header/Footer','W','Y',100,0,0,TO_DATE('2021-07-28 17:09:07','YYYY-MM-DD HH24:MI:SS'),TO_DATE('2021-07-28 17:09:07','YYYY-MM-DD HH24:MI:SS'),100,'D',200100)
;
-- July 28, 2021 5:09:08 PM SGT
INSERT INTO AD_TreeNode (AD_Client_ID,AD_Org_ID, IsActive,Created,CreatedBy,Updated,UpdatedBy, AD_Tree_ID, Node_ID, Parent_ID, SeqNo, AD_TreeNode_UU) SELECT t.AD_Client_ID, 0, 'Y', SysDate, 100, SysDate, 100,t.AD_Tree_ID, 200156, 0, 999, Generate_UUID() FROM AD_Tree t WHERE t.AD_Client_ID=0 AND t.IsActive='Y' AND t.IsAllNodes='Y' AND t.TreeType='TL' AND t.AD_Table_ID=116 AND NOT EXISTS (SELECT * FROM AD_TreeNode e WHERE e.AD_Tree_ID=t.AD_Tree_ID AND Node_ID=200156)
;
-- July 28, 2021 5:09:08 PM SGT
INSERT INTO AD_TreeNodeMM (AD_Client_ID,AD_Org_ID, IsActive,Created,CreatedBy,Updated,UpdatedBy, AD_Tree_ID, Node_ID, Parent_ID, SeqNo, AD_TreeNodeMM_UU) SELECT t.AD_Client_ID, 0, 'Y', SysDate, 100, SysDate, 100,t.AD_Tree_ID, 200156, 0, 999, Generate_UUID() FROM AD_Tree t WHERE t.AD_Client_ID=0 AND t.IsActive='Y' AND t.IsAllNodes='Y' AND t.TreeType='MM' AND NOT EXISTS (SELECT * FROM AD_TreeNodeMM e WHERE e.AD_Tree_ID=t.AD_Tree_ID AND Node_ID=200156)
;
-- July 28, 2021 5:09:28 PM SGT
UPDATE AD_TreeNodeMM SET Parent_ID=326, SeqNo=9, Updated=SysDate WHERE AD_Tree_ID=10 AND Node_ID=200156
;
-- July 28, 2021 5:15:07 PM SGT
-- AP2-274 Configure Header and Footer for financial reports
INSERT INTO AD_Column (AD_Column_ID,SeqNoSelection,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,SeqNo,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,FKConstraintType,AD_Element_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213521,0,'N',0,'N','N','N',0,'N',22,'N','N','N','Y','6f222c63-afaf-4774-a704-d2437b879cb6',TO_DATE('2021-07-28 17:16:57','YYYY-MM-DD HH24:MI:SS'),'N','AD_PrintHeaderFooter_ID','Print Header/Footer','Y','Y',100,100,'N',0,0,TO_DATE('2021-07-28 17:16:57','YYYY-MM-DD HH24:MI:SS'),'N','U','N','N',203210,493,19,'N')
;
-- July 28, 2021 5:17:04 PM SGT
INSERT INTO AD_TreeNode (AD_Client_ID,AD_Org_ID, IsActive,Created,CreatedBy,Updated,UpdatedBy, AD_Tree_ID, Node_ID, Parent_ID, SeqNo, AD_TreeNode_UU) SELECT t.AD_Client_ID, 0, 'Y', SysDate, 100, SysDate, 100,t.AD_Tree_ID, 200006, 0, 999, Generate_UUID() FROM AD_Tree t WHERE t.AD_Client_ID=0 AND t.IsActive='Y' AND t.IsAllNodes='Y' AND t.TreeType='TL' AND t.AD_Table_ID=282 AND NOT EXISTS (SELECT * FROM AD_TreeNode e WHERE e.AD_Tree_ID=t.AD_Tree_ID AND Node_ID=200006)
;
-- July 28, 2021 5:17:05 PM SGT
UPDATE AD_Column SET FKConstraintType='N', FKConstraintName='ADPrintHeaderFooter_ADPrintFor',Updated=TO_DATE('2021-07-28 17:17:05','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Column_ID=213521
;
-- July 28, 2021 5:17:05 PM SGT
ALTER TABLE AD_PrintFormat ADD AD_PrintHeaderFooter_ID NUMBER(10) DEFAULT NULL
;
-- July 28, 2021 5:17:05 PM SGT
ALTER TABLE AD_PrintFormat ADD CONSTRAINT ADPrintHeaderFooter_ADPrintFor FOREIGN KEY (AD_PrintHeaderFooter_ID) REFERENCES ad_printheaderfooter(ad_printheaderfooter_id) DEFERRABLE INITIALLY DEFERRED
;
-- July 28, 2021 5:18:08 PM SGT
INSERT INTO AD_TreeNode (AD_Client_ID,AD_Org_ID, IsActive,Created,CreatedBy,Updated,UpdatedBy, AD_Tree_ID, Node_ID, Parent_ID, SeqNo, AD_TreeNode_UU) SELECT t.AD_Client_ID, 0, 'Y', SysDate, 100, SysDate, 100,t.AD_Tree_ID, 200007, 0, 999, Generate_UUID() FROM AD_Tree t WHERE t.AD_Client_ID=0 AND t.IsActive='Y' AND t.IsAllNodes='Y' AND t.TreeType='TL' AND t.AD_Table_ID=282 AND NOT EXISTS (SELECT * FROM AD_TreeNode e WHERE e.AD_Tree_ID=t.AD_Tree_ID AND Node_ID=200007)
;
-- July 28, 2021 5:18:09 PM SGT
INSERT INTO AD_Field (AD_Field_ID,IsEncrypted,DisplayLength,IsSameLine,IsHeading,SeqNo,IsCentrallyMaintained,IsReadOnly,AD_Org_ID,Updated,Name,AD_Field_UU,IsDisplayed,IsFieldOnly,CreatedBy,UpdatedBy,IsActive,IsDisplayedGrid,SeqNoGrid,AD_Client_ID,Created,ColumnSpan,AD_Column_ID,EntityType,AD_Tab_ID) VALUES (205584,'N',22,'N','N',260,'Y','N',0,TO_DATE('2021-07-28 17:18:08','YYYY-MM-DD HH24:MI:SS'),'Print Header/Footer','baaa8cef-c923-4a89-b73b-06e6345c2bd4','Y','N',100,100,'Y','Y',260,0,TO_DATE('2021-07-28 17:18:08','YYYY-MM-DD HH24:MI:SS'),2,213521,'U',425)
;
-- July 28, 2021 5:18:16 PM SGT
UPDATE AD_Column SET EntityType='D',Updated=TO_DATE('2021-07-28 17:18:16','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Column_ID=213521
;
-- July 28, 2021 5:20:18 PM SGT
UPDATE AD_Field SET SeqNo=125, AD_Val_Rule_ID=NULL, SeqNoGrid=125, AD_Reference_Value_ID=NULL, EntityType='D', IsToolbarButton=NULL,Updated=TO_DATE('2021-07-28 17:20:18','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Field_ID=205584
;
-- July 28, 2021 5:20:43 PM SGT
UPDATE AD_Field SET DisplayLogic='@IsStandardHeaderFooter@=N', AD_Val_Rule_ID=NULL, AD_Reference_Value_ID=NULL, IsToolbarButton=NULL,Updated=TO_DATE('2021-07-28 17:20:43','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Field_ID=205584
;
-- July 28, 2021 5:20:54 PM SGT
UPDATE AD_Field SET AD_Val_Rule_ID=NULL, XPosition=4, AD_Reference_Value_ID=NULL, IsToolbarButton=NULL,Updated=TO_DATE('2021-07-28 17:20:54','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Field_ID=205584
;
-- July 28, 2021 5:22:33 PM SGT
UPDATE AD_Column SET IsUpdateable='Y',Updated=TO_DATE('2021-07-28 17:22:33','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Column_ID=213521
;
-- Jul 29, 2021, 2:54:24 PM MYT
UPDATE AD_Column SET IsMandatory='Y', SeqNoSelection=10,Updated=TO_DATE('2021-07-29 14:54:24','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Column_ID=213520
;
-- Jul 29, 2021, 2:54:29 PM MYT
ALTER TABLE AD_PrintHeaderFooter MODIFY SourceClassName VARCHAR2(255 CHAR)
;
-- Jul 29, 2021, 2:54:29 PM MYT
ALTER TABLE AD_PrintHeaderFooter MODIFY SourceClassName NOT NULL
;
-- Jul 29, 2021, 2:56:11 PM MYT
INSERT INTO AD_TableIndex (AD_Client_ID,AD_Org_ID,AD_TableIndex_ID,AD_TableIndex_UU,Created,CreatedBy,EntityType,IsActive,Name,Updated,UpdatedBy,AD_Table_ID,IsCreateConstraint,IsUnique,Processing,TableIndexDrop,IsKey) VALUES (0,0,201089,'87fdd27c-eb34-4183-a0e1-92ad668dc7c8',TO_DATE('2021-07-29 14:56:10','YYYY-MM-DD HH24:MI:SS'),100,'D','Y','AD_PrintHeaderFooter_Name_Idx',TO_DATE('2021-07-29 14:56:10','YYYY-MM-DD HH24:MI:SS'),100,200240,'Y','Y','N','N','N')
;
-- Jul 29, 2021, 2:56:23 PM MYT
INSERT INTO AD_IndexColumn (AD_Client_ID,AD_Org_ID,AD_IndexColumn_ID,AD_IndexColumn_UU,Created,CreatedBy,EntityType,IsActive,Updated,UpdatedBy,AD_Column_ID,AD_TableIndex_ID,SeqNo) VALUES (0,0,201428,'33e8b8f8-cab8-4d3e-a979-473e5226f145',TO_DATE('2021-07-29 14:56:23','YYYY-MM-DD HH24:MI:SS'),100,'D','Y',TO_DATE('2021-07-29 14:56:23','YYYY-MM-DD HH24:MI:SS'),100,213508,201089,10)
;
-- Jul 29, 2021, 2:56:34 PM MYT
INSERT INTO AD_IndexColumn (AD_Client_ID,AD_Org_ID,AD_IndexColumn_ID,AD_IndexColumn_UU,Created,CreatedBy,EntityType,IsActive,Updated,UpdatedBy,AD_Column_ID,AD_TableIndex_ID,SeqNo) VALUES (0,0,201429,'afa25fab-0832-48cf-bb0e-9ed3fe5c22b3',TO_DATE('2021-07-29 14:56:33','YYYY-MM-DD HH24:MI:SS'),100,'D','Y',TO_DATE('2021-07-29 14:56:33','YYYY-MM-DD HH24:MI:SS'),100,213517,201089,20)
;
-- Jul 29, 2021, 2:56:40 PM MYT
ALTER TABLE AD_PrintHeaderFooter ADD CONSTRAINT AD_PrintHeaderFooter_Name_Idx UNIQUE (AD_Client_ID,Name)
;
-- Jul 29, 2021, 2:59:52 PM MYT
UPDATE AD_TableIndex SET AD_Message_ID=502,Updated=TO_DATE('2021-07-29 14:59:52','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_TableIndex_ID=201089
;
SELECT register_migration_script('202107281652_IDEMPIERE-4894.sql') FROM dual
;

View File

@ -0,0 +1,246 @@
-- IDEMPIERE-4894 OSGi Interface to support custom header and footer
INSERT INTO AD_Table (AccessLevel,AD_Client_ID,AD_Org_ID,AD_Table_ID,AD_Table_UU,Created,CreatedBy,Description,EntityType,IsActive,IsCentrallyMaintained,IsChangeLog,IsDeleteable,IsHighVolume,IsSecurityEnabled,IsView,LoadSeq,Name,Processing,ReplicationType,TableName,Updated,UpdatedBy) VALUES ('4',0,0,200240,'4e785f3f-dce9-4f27-900a-504122d447d0',TO_TIMESTAMP('2021-07-28 17:00:08','YYYY-MM-DD HH24:MI:SS'),100,NULL,'D','Y','Y','Y','Y','N','N','N',145,'Print Header/Footer','N','L','AD_PrintHeaderFooter',TO_TIMESTAMP('2021-07-28 17:00:08','YYYY-MM-DD HH24:MI:SS'),100)
;
-- July 28, 2021 5:00:11 PM SGT
INSERT INTO AD_Sequence (AD_Client_ID,AD_Org_ID,AD_Sequence_ID,AD_Sequence_UU,Created,CreatedBy,CurrentNext,CurrentNextSys,Description,IncrementNo,IsActive,IsAudited,IsAutoSequence,IsTableID,Name,StartNewYear,StartNo,Updated,UpdatedBy) VALUES (0,0,200304,'55b3e131-60d2-46fa-9665-ba039f2f37ee',TO_TIMESTAMP('2021-07-28 17:00:10','YYYY-MM-DD HH24:MI:SS'),100,1000000,200000,'Table AD_PrintHeaderFooter',1,'Y','N','Y','Y','AD_PrintHeaderFooter','N',1000000,TO_TIMESTAMP('2021-07-28 17:00:10','YYYY-MM-DD HH24:MI:SS'),100)
;
-- July 28, 2021 5:00:32 PM SGT
INSERT INTO AD_TreeNode (AD_Client_ID,AD_Org_ID, IsActive,Created,CreatedBy,Updated,UpdatedBy, AD_Tree_ID, Node_ID, Parent_ID, SeqNo, AD_TreeNode_UU) SELECT t.AD_Client_ID, 0, 'Y', statement_timestamp(), 100, statement_timestamp(), 100,t.AD_Tree_ID, 200003, 0, 999, Generate_UUID() FROM AD_Tree t WHERE t.AD_Client_ID=0 AND t.IsActive='Y' AND t.IsAllNodes='Y' AND t.TreeType='TL' AND t.AD_Table_ID=282 AND NOT EXISTS (SELECT * FROM AD_TreeNode e WHERE e.AD_Tree_ID=t.AD_Tree_ID AND Node_ID=200003)
;
-- July 28, 2021 5:00:34 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,DefaultValue,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,FKConstraintType,AD_Element_ID,AD_Val_Rule_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213508,'N',1,'Y','N','N','N',22,'N','N','N','N','d49721fe-2f15-43e9-ba7a-b7472cc06304',TO_TIMESTAMP('2021-07-28 17:00:32','YYYY-MM-DD HH24:MI:SS'),'N','AD_Client_ID','Client/Tenant for this installation.','@#AD_Client_ID@','A Client is a company or a legal entity. You cannot share data between Clients. Tenant is a synonym for Client.','Client','N','Y',100,100,'N',0,0,TO_TIMESTAMP('2021-07-28 17:00:32','YYYY-MM-DD HH24:MI:SS'),'N','D','N','D',102,129,200240,19,'N')
;
-- July 28, 2021 5:00:37 PM SGT
INSERT INTO AD_Element (AD_Element_ID,ColumnName,Updated,Name,PrintName,AD_Element_UU,IsActive,Created,AD_Org_ID,CreatedBy,UpdatedBy,AD_Client_ID,EntityType) VALUES (203210,'AD_PrintHeaderFooter_ID',TO_TIMESTAMP('2021-07-28 17:00:35','YYYY-MM-DD HH24:MI:SS'),'Print Header/Footer','Print Header/Footer','1c0cdce7-c3ca-4cdd-8ce2-154f0bf3c826','Y',TO_TIMESTAMP('2021-07-28 17:00:35','YYYY-MM-DD HH24:MI:SS'),0,100,100,0,'D')
;
-- July 28, 2021 5:00:38 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,AD_Element_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213509,'N',1,'Y','N','N','N',22,'N','Y','N','N','2ab090db-0460-49a6-b263-ab555919fac7',TO_TIMESTAMP('2021-07-28 17:00:35','YYYY-MM-DD HH24:MI:SS'),'N','AD_PrintHeaderFooter_ID','Print Header/Footer','N','Y',100,100,'N',0,0,TO_TIMESTAMP('2021-07-28 17:00:35','YYYY-MM-DD HH24:MI:SS'),'N','D','N',203210,200240,13,'N')
;
-- July 28, 2021 5:00:40 PM SGT
INSERT INTO AD_Element (AD_Element_ID,ColumnName,Updated,Name,PrintName,AD_Element_UU,IsActive,Created,AD_Org_ID,CreatedBy,UpdatedBy,AD_Client_ID,EntityType) VALUES (203211,'AD_PrintHeaderFooter_UU',TO_TIMESTAMP('2021-07-28 17:00:38','YYYY-MM-DD HH24:MI:SS'),'AD_PrintHeaderFooter_UU','AD_PrintHeaderFooter_UU','b38888ed-e649-4d99-a6b4-206305fba4af','Y',TO_TIMESTAMP('2021-07-28 17:00:38','YYYY-MM-DD HH24:MI:SS'),0,100,100,0,'D')
;
-- July 28, 2021 5:00:42 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,AD_Element_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213510,'N',1.00,'N','N','N','N',36,'N','N','N','Y','96f6a17f-1cbb-46a5-8071-a416efa85693',TO_TIMESTAMP('2021-07-28 17:00:38','YYYY-MM-DD HH24:MI:SS'),'Y','AD_PrintHeaderFooter_UU','AD_PrintHeaderFooter_UU','N','Y',100,100,'N',0,0,TO_TIMESTAMP('2021-07-28 17:00:38','YYYY-MM-DD HH24:MI:SS'),'N','D','N',203211,200240,10,'N')
;
-- July 28, 2021 5:00:43 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,FKConstraintType,AD_Element_ID,AD_Reference_Value_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213511,'N',1,'N','N','N','N',6,'N','N','N','Y','b9230734-b179-4c64-9cf8-ecec62fc6e49',TO_TIMESTAMP('2021-07-28 17:00:42','YYYY-MM-DD HH24:MI:SS'),'Y','AD_Language','Language for this entity','The Language identifies the language to use for display and formatting','Language','Y','Y',100,100,'N',0,0,TO_TIMESTAMP('2021-07-28 17:00:42','YYYY-MM-DD HH24:MI:SS'),'N','D','N','N',109,106,200240,18,'N')
;
-- July 28, 2021 5:00:46 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,DefaultValue,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,FKConstraintType,AD_Element_ID,AD_Val_Rule_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213512,'N',1,'Y','N','N','N',22,'N','N','N','N','50c1a0f8-dde9-4557-b4a3-5524424eafe5',TO_TIMESTAMP('2021-07-28 17:00:43','YYYY-MM-DD HH24:MI:SS'),'N','AD_Org_ID','Organizational entity within client','@#AD_Org_ID@','An organization is a unit of your client or legal entity - examples are store, department. You can share data between organizations.','Organization','N','Y',100,100,'N',0,0,TO_TIMESTAMP('2021-07-28 17:00:43','YYYY-MM-DD HH24:MI:SS'),'N','D','N','D',113,104,200240,19,'N')
;
-- July 28, 2021 5:00:48 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,AD_Element_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213513,'N',1,'N','N','N','N',2000,'N','N','N','Y','811cd8be-9f60-4d1b-9f5b-3eb514aa3148',TO_TIMESTAMP('2021-07-28 17:00:46','YYYY-MM-DD HH24:MI:SS'),'Y','Code','Validation Code','The Validation Code displays the date, time and message of the error.','Validation code','Y','Y',100,100,'N',0,0,TO_TIMESTAMP('2021-07-28 17:00:46','YYYY-MM-DD HH24:MI:SS'),'N','D','N',227,200240,10,'N')
;
-- July 28, 2021 5:00:49 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,DefaultValue,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,AD_Element_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213514,'N',1,'Y','N','N','N',7,'N','N','N','N','0666c09c-9082-4a51-b936-9cf95a76c171',TO_TIMESTAMP('2021-07-28 17:00:48','YYYY-MM-DD HH24:MI:SS'),'N','Created','Date this record was created','SYSDATE','The Created field indicates the date that this record was created.','Created','N','Y',100,100,'N',0,0,TO_TIMESTAMP('2021-07-28 17:00:48','YYYY-MM-DD HH24:MI:SS'),'N','D','N',245,200240,16,'N')
;
-- July 28, 2021 5:00:50 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,FKConstraintType,AD_Element_ID,AD_Reference_Value_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213515,'N',1,'Y','N','N','N',22,'N','N','N','N','6754886f-9531-4435-9881-6aeb117c5d9f',TO_TIMESTAMP('2021-07-28 17:00:49','YYYY-MM-DD HH24:MI:SS'),'N','CreatedBy','User who created this records','The Created By field indicates the user who created this record.','Created By','N','Y',100,100,'N',0,0,TO_TIMESTAMP('2021-07-28 17:00:49','YYYY-MM-DD HH24:MI:SS'),'N','D','N','D',246,110,200240,18,'N')
;
-- July 28, 2021 5:00:52 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,DefaultValue,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,AD_Element_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213516,'N',1,'Y','N','N','N',1,'N','N','N','Y','11b3d43d-e42d-4212-b5ff-be3f4344b044',TO_TIMESTAMP('2021-07-28 17:00:50','YYYY-MM-DD HH24:MI:SS'),'Y','IsActive','The record is active in the system','Y','There are two methods of making records unavailable in the system: One is to delete the record, the other is to de-activate the record. A de-activated record is not available for selection, but available for reports.
There are two reasons for de-activating and not deleting records:
(1) The system requires the record for audit purposes.
(2) The record is referenced by other records. E.g., you cannot delete a Business Partner, if there are invoices for this partner record existing. You de-activate the Business Partner and prevent that this record is used for future entries.','Active','N','Y',100,100,'N',0,0,TO_TIMESTAMP('2021-07-28 17:00:50','YYYY-MM-DD HH24:MI:SS'),'N','D','N',348,200240,20,'N')
;
-- July 28, 2021 5:00:52 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,SeqNo,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,AD_Element_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213517,'N',1,'Y','N','Y',1,'N',60,'Y','N','N','Y','0d3ae0bf-64e9-4aef-a657-d0ccc402bf30',TO_TIMESTAMP('2021-07-28 17:00:52','YYYY-MM-DD HH24:MI:SS'),'Y','Name','Alphanumeric identifier of the entity','The name of an entity (record) is used as an default search option in addition to the search key. The name is up to 60 characters in length.','Name','Y','Y',100,100,'N',0,0,TO_TIMESTAMP('2021-07-28 17:00:52','YYYY-MM-DD HH24:MI:SS'),'N','D','N',469,200240,10,'N')
;
-- July 28, 2021 5:00:53 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,DefaultValue,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,AD_Element_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213518,'N',1,'Y','N','N','N',7,'N','N','N','N','07ea1bc7-a0b4-4bc5-952a-35cdb8da475f',TO_TIMESTAMP('2021-07-28 17:00:52','YYYY-MM-DD HH24:MI:SS'),'N','Updated','Date this record was updated','SYSDATE','The Updated field indicates the date that this record was updated.','Updated','N','Y',100,100,'N',0,0,TO_TIMESTAMP('2021-07-28 17:00:52','YYYY-MM-DD HH24:MI:SS'),'N','D','N',607,200240,16,'N')
;
-- July 28, 2021 5:01:02 PM SGT
INSERT INTO AD_Column (AD_Column_ID,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,Help,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,FKConstraintType,AD_Element_ID,AD_Reference_Value_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213519,'N',1,'Y','N','N','N',22,'N','N','N','N','29ac01ef-6553-4f9a-853d-40423438a032',TO_TIMESTAMP('2021-07-28 17:00:53','YYYY-MM-DD HH24:MI:SS'),'N','UpdatedBy','User who updated this records','The Updated By field indicates the user who updated this record.','Updated By','N','Y',100,100,'N',0,0,TO_TIMESTAMP('2021-07-28 17:00:53','YYYY-MM-DD HH24:MI:SS'),'N','D','N','D',608,110,200240,18,'N')
;
-- July 28, 2021 5:01:27 PM SGT
DELETE FROM AD_Column_Trl WHERE AD_Column_ID=213511
;
-- July 28, 2021 5:01:27 PM SGT
DELETE FROM AD_Column WHERE AD_Column_ID=213511
;
-- July 28, 2021 5:01:29 PM SGT
DELETE FROM AD_Column_Trl WHERE AD_Column_ID=213513
;
-- July 28, 2021 5:01:29 PM SGT
DELETE FROM AD_Column WHERE AD_Column_ID=213513
;
-- July 28, 2021 5:03:53 PM SGT
INSERT INTO AD_Column (AD_Column_ID,SeqNoSelection,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,SeqNo,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Description,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,AD_Element_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213520,0,'N',0,'N','N','N',0,'N',255,'Y','N','N','Y','3e4f5498-0035-486a-b14a-846b501ddb40',TO_TIMESTAMP('2021-07-28 17:03:52','YYYY-MM-DD HH24:MI:SS'),'Y','SourceClassName','Source Class Name','Source Class','Y','Y',100,100,'N',0,0,TO_TIMESTAMP('2021-07-28 17:03:52','YYYY-MM-DD HH24:MI:SS'),'N','U','N',2942,200240,10,'N')
;
-- July 28, 2021 5:03:56 PM SGT
UPDATE AD_Column SET EntityType='D',Updated=TO_TIMESTAMP('2021-07-28 17:03:56','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Column_ID=213520
;
-- July 28, 2021 5:04:16 PM SGT
INSERT INTO AD_TreeNode (AD_Client_ID,AD_Org_ID, IsActive,Created,CreatedBy,Updated,UpdatedBy, AD_Tree_ID, Node_ID, Parent_ID, SeqNo, AD_TreeNode_UU) SELECT t.AD_Client_ID, 0, 'Y', statement_timestamp(), 100, statement_timestamp(), 100,t.AD_Tree_ID, 200004, 0, 999, Generate_UUID() FROM AD_Tree t WHERE t.AD_Client_ID=0 AND t.IsActive='Y' AND t.IsAllNodes='Y' AND t.TreeType='TL' AND t.AD_Table_ID=282 AND NOT EXISTS (SELECT * FROM AD_TreeNode e WHERE e.AD_Tree_ID=t.AD_Tree_ID AND Node_ID=200004)
;
-- July 28, 2021 5:04:17 PM SGT
CREATE TABLE AD_PrintHeaderFooter (AD_Client_ID NUMERIC(10) NOT NULL, AD_Org_ID NUMERIC(10) NOT NULL, AD_PrintHeaderFooter_ID NUMERIC(10) NOT NULL, AD_PrintHeaderFooter_UU VARCHAR(36) DEFAULT NULL , Created TIMESTAMP DEFAULT statement_timestamp() NOT NULL, CreatedBy NUMERIC(10) NOT NULL, IsActive CHAR(1) DEFAULT 'Y' CHECK (IsActive IN ('Y','N')) NOT NULL, Name VARCHAR(60) NOT NULL, SourceClassName VARCHAR(255) DEFAULT NULL , Updated TIMESTAMP DEFAULT statement_timestamp() NOT NULL, UpdatedBy NUMERIC(10) NOT NULL, CONSTRAINT AD_PrintHeaderFooter_Key PRIMARY KEY (AD_PrintHeaderFooter_ID), CONSTRAINT AD_PrintHeaderFooter_UU_idx UNIQUE (AD_PrintHeaderFooter_UU))
;
-- July 28, 2021 5:04:58 PM SGT
INSERT INTO AD_Window (WindowType,Help,IsSOTrx,IsDefault,IsBetaFunctionality,Processing,AD_Org_ID,Name,Description,AD_Window_ID,AD_Window_UU,IsActive,AD_Client_ID,Updated,CreatedBy,UpdatedBy,EntityType,Created) VALUES ('M',NULL,'Y','N','N','N',0,'Print Header/Footer','Maintain Print Header/Footer',200100,'681b8621-d60e-4d33-9c10-ca6effe4b23e','Y',0,TO_TIMESTAMP('2021-07-28 17:04:57','YYYY-MM-DD HH24:MI:SS'),100,100,'D',TO_TIMESTAMP('2021-07-28 17:04:57','YYYY-MM-DD HH24:MI:SS'))
;
-- July 28, 2021 5:06:41 PM SGT
INSERT INTO AD_Tab (AD_Client_ID,AD_Org_ID,AD_Tab_ID,AD_Table_ID,AD_Tab_UU,AD_Window_ID,Created,CreatedBy,EntityType,HasTree,ImportFields,IsActive,IsAdvancedTab,IsInfoTab,IsInsertRecord,IsReadOnly,IsSingleRow,IsSortTab,IsTranslationTab,Name,Processing,SeqNo,TabLevel,TreeDisplayedOn,Updated,UpdatedBy) VALUES (0,0,200249,200240,'b3beffb9-ab5f-4d40-9a6b-2f849306e9e6',200100,TO_TIMESTAMP('2021-07-28 17:06:39','YYYY-MM-DD HH24:MI:SS'),100,'D','N','N','Y','N','N','Y','N','Y','N','N','Print Header/Footer','N',10,0,'M',TO_TIMESTAMP('2021-07-28 17:06:39','YYYY-MM-DD HH24:MI:SS'),100)
;
-- July 28, 2021 5:06:57 PM SGT
INSERT INTO AD_TreeNode (AD_Client_ID,AD_Org_ID, IsActive,Created,CreatedBy,Updated,UpdatedBy, AD_Tree_ID, Node_ID, Parent_ID, SeqNo, AD_TreeNode_UU) SELECT t.AD_Client_ID, 0, 'Y', statement_timestamp(), 100, statement_timestamp(), 100,t.AD_Tree_ID, 200005, 0, 999, Generate_UUID() FROM AD_Tree t WHERE t.AD_Client_ID=0 AND t.IsActive='Y' AND t.IsAllNodes='Y' AND t.TreeType='TL' AND t.AD_Table_ID=282 AND NOT EXISTS (SELECT * FROM AD_TreeNode e WHERE e.AD_Tree_ID=t.AD_Tree_ID AND Node_ID=200005)
;
-- July 28, 2021 5:07:00 PM SGT
INSERT INTO AD_Field (AD_Field_ID,IsEncrypted,DisplayLength,IsSameLine,IsHeading,SeqNo,IsCentrallyMaintained,IsReadOnly,Help,AD_Org_ID,Updated,Description,Name,AD_Field_UU,IsDisplayed,IsFieldOnly,CreatedBy,UpdatedBy,IsActive,IsDisplayedGrid,SeqNoGrid,AD_Client_ID,Created,ColumnSpan,AD_Column_ID,EntityType,AD_Tab_ID) VALUES (205577,'N',22,'N','N',10,'Y','N','A Client is a company or a legal entity. You cannot share data between Clients. Tenant is a synonym for Client.',0,TO_TIMESTAMP('2021-07-28 17:06:58','YYYY-MM-DD HH24:MI:SS'),'Client/Tenant for this installation.','Client','4bc05f5f-d904-4027-a467-508d13ba967a','Y','N',100,100,'Y','Y',10,0,TO_TIMESTAMP('2021-07-28 17:06:58','YYYY-MM-DD HH24:MI:SS'),2,213508,'D',200249)
;
-- July 28, 2021 5:07:03 PM SGT
INSERT INTO AD_Field (AD_Field_ID,IsEncrypted,DisplayLength,IsSameLine,IsHeading,SeqNo,IsCentrallyMaintained,IsReadOnly,Help,AD_Org_ID,Updated,Description,Name,AD_Field_UU,IsDisplayed,IsFieldOnly,IsAllowCopy,CreatedBy,UpdatedBy,IsActive,IsDisplayedGrid,SeqNoGrid,XPosition,AD_Client_ID,Created,ColumnSpan,AD_Column_ID,EntityType,AD_Tab_ID) VALUES (205578,'N',22,'N','N',20,'Y','N','An organization is a unit of your client or legal entity - examples are store, department. You can share data between organizations.',0,TO_TIMESTAMP('2021-07-28 17:07:00','YYYY-MM-DD HH24:MI:SS'),'Organizational entity within client','Organization','051d2a8a-4dbd-4706-9f80-897e5b3986c4','Y','N','Y',100,100,'Y','Y',20,4,0,TO_TIMESTAMP('2021-07-28 17:07:00','YYYY-MM-DD HH24:MI:SS'),2,213512,'D',200249)
;
-- July 28, 2021 5:07:05 PM SGT
INSERT INTO AD_Field (AD_Field_ID,IsEncrypted,DisplayLength,IsSameLine,IsHeading,SeqNo,IsCentrallyMaintained,IsReadOnly,Help,AD_Org_ID,Updated,Description,Name,AD_Field_UU,IsDisplayed,IsFieldOnly,CreatedBy,UpdatedBy,IsActive,IsDisplayedGrid,SeqNoGrid,AD_Client_ID,Created,ColumnSpan,AD_Column_ID,EntityType,AD_Tab_ID) VALUES (205579,'N',60,'N','N',30,'Y','N','The name of an entity (record) is used as an default search option in addition to the search key. The name is up to 60 characters in length.',0,TO_TIMESTAMP('2021-07-28 17:07:03','YYYY-MM-DD HH24:MI:SS'),'Alphanumeric identifier of the entity','Name','acc95b14-bff5-4d21-8b2d-c3a07d008d4e','Y','N',100,100,'Y','Y',30,0,TO_TIMESTAMP('2021-07-28 17:07:03','YYYY-MM-DD HH24:MI:SS'),5,213517,'D',200249)
;
-- July 28, 2021 5:07:06 PM SGT
INSERT INTO AD_Field (AD_Field_ID,IsEncrypted,DisplayLength,IsSameLine,IsHeading,IsCentrallyMaintained,IsReadOnly,AD_Org_ID,Updated,Name,AD_Field_UU,IsDisplayed,IsFieldOnly,CreatedBy,UpdatedBy,IsActive,IsDisplayedGrid,AD_Client_ID,Created,ColumnSpan,AD_Column_ID,EntityType,AD_Tab_ID) VALUES (205580,'N',22,'N','N','Y','N',0,TO_TIMESTAMP('2021-07-28 17:07:05','YYYY-MM-DD HH24:MI:SS'),'Print Header/Footer','636434ea-cb1a-4f20-8ca7-34c1fcf6a4ff','N','N',100,100,'Y','N',0,TO_TIMESTAMP('2021-07-28 17:07:05','YYYY-MM-DD HH24:MI:SS'),2,213509,'D',200249)
;
-- July 28, 2021 5:07:08 PM SGT
INSERT INTO AD_Field (AD_Field_ID,IsEncrypted,DisplayLength,IsSameLine,IsHeading,IsCentrallyMaintained,IsReadOnly,AD_Org_ID,Updated,Name,AD_Field_UU,IsDisplayed,IsFieldOnly,CreatedBy,UpdatedBy,IsActive,IsDisplayedGrid,AD_Client_ID,Created,ColumnSpan,AD_Column_ID,EntityType,AD_Tab_ID) VALUES (205581,'N',36,'N','N','Y','N',0,TO_TIMESTAMP('2021-07-28 17:07:06','YYYY-MM-DD HH24:MI:SS'),'AD_PrintHeaderFooter_UU','0374e4a2-7b93-40d8-9928-f883f54803ad','N','N',100,100,'Y','N',0,TO_TIMESTAMP('2021-07-28 17:07:06','YYYY-MM-DD HH24:MI:SS'),2,213510,'D',200249)
;
-- July 28, 2021 5:07:09 PM SGT
INSERT INTO AD_Field (AD_Field_ID,IsEncrypted,DisplayLength,IsSameLine,IsHeading,SeqNo,IsCentrallyMaintained,IsReadOnly,AD_Org_ID,Updated,Description,Name,AD_Field_UU,IsDisplayed,IsFieldOnly,CreatedBy,UpdatedBy,IsActive,IsDisplayedGrid,SeqNoGrid,AD_Client_ID,Created,ColumnSpan,AD_Column_ID,EntityType,AD_Tab_ID) VALUES (205582,'N',255,'N','N',40,'Y','N',0,TO_TIMESTAMP('2021-07-28 17:07:08','YYYY-MM-DD HH24:MI:SS'),'Source Class Name','Source Class','246e8579-9378-45c8-8c5e-dbc77f29abc2','Y','N',100,100,'Y','Y',40,0,TO_TIMESTAMP('2021-07-28 17:07:08','YYYY-MM-DD HH24:MI:SS'),5,213520,'D',200249)
;
-- July 28, 2021 5:07:10 PM SGT
INSERT INTO AD_Field (AD_Field_ID,IsEncrypted,DisplayLength,IsSameLine,IsHeading,SeqNo,IsCentrallyMaintained,IsReadOnly,Help,AD_Org_ID,Updated,Description,Name,AD_Field_UU,IsDisplayed,IsFieldOnly,CreatedBy,UpdatedBy,IsActive,IsDisplayedGrid,SeqNoGrid,XPosition,AD_Client_ID,Created,ColumnSpan,AD_Column_ID,EntityType,AD_Tab_ID) VALUES (205583,'N',1,'N','N',50,'Y','N','There are two methods of making records unavailable in the system: One is to delete the record, the other is to de-activate the record. A de-activated record is not available for selection, but available for reports.
There are two reasons for de-activating and not deleting records:
(1) The system requires the record for audit purposes.
(2) The record is referenced by other records. E.g., you cannot delete a Business Partner, if there are invoices for this partner record existing. You de-activate the Business Partner and prevent that this record is used for future entries.',0,TO_TIMESTAMP('2021-07-28 17:07:09','YYYY-MM-DD HH24:MI:SS'),'The record is active in the system','Active','f1bbff39-345a-4511-9501-5303b4fada21','Y','N',100,100,'Y','Y',50,2,0,TO_TIMESTAMP('2021-07-28 17:07:09','YYYY-MM-DD HH24:MI:SS'),2,213516,'D',200249)
;
-- July 28, 2021 5:09:08 PM SGT
INSERT INTO AD_Menu (AD_Menu_ID,IsSummary,AD_Menu_UU,IsSOTrx,IsReadOnly,IsCentrallyMaintained,Name,Description,"action",IsActive,CreatedBy,AD_Org_ID,AD_Client_ID,Created,Updated,UpdatedBy,EntityType,AD_Window_ID) VALUES (200156,'N','4544341f-cd36-4d72-8484-2f5908a9dfd9','Y','N','Y','Print Header/Footer','Maintain Print Header/Footer','W','Y',100,0,0,TO_TIMESTAMP('2021-07-28 17:09:07','YYYY-MM-DD HH24:MI:SS'),TO_TIMESTAMP('2021-07-28 17:09:07','YYYY-MM-DD HH24:MI:SS'),100,'D',200100)
;
-- July 28, 2021 5:09:08 PM SGT
INSERT INTO AD_TreeNode (AD_Client_ID,AD_Org_ID, IsActive,Created,CreatedBy,Updated,UpdatedBy, AD_Tree_ID, Node_ID, Parent_ID, SeqNo, AD_TreeNode_UU) SELECT t.AD_Client_ID, 0, 'Y', statement_timestamp(), 100, statement_timestamp(), 100,t.AD_Tree_ID, 200156, 0, 999, Generate_UUID() FROM AD_Tree t WHERE t.AD_Client_ID=0 AND t.IsActive='Y' AND t.IsAllNodes='Y' AND t.TreeType='TL' AND t.AD_Table_ID=116 AND NOT EXISTS (SELECT * FROM AD_TreeNode e WHERE e.AD_Tree_ID=t.AD_Tree_ID AND Node_ID=200156)
;
-- July 28, 2021 5:09:08 PM SGT
INSERT INTO AD_TreeNodeMM (AD_Client_ID,AD_Org_ID, IsActive,Created,CreatedBy,Updated,UpdatedBy, AD_Tree_ID, Node_ID, Parent_ID, SeqNo, AD_TreeNodeMM_UU) SELECT t.AD_Client_ID, 0, 'Y', statement_timestamp(), 100, statement_timestamp(), 100,t.AD_Tree_ID, 200156, 0, 999, Generate_UUID() FROM AD_Tree t WHERE t.AD_Client_ID=0 AND t.IsActive='Y' AND t.IsAllNodes='Y' AND t.TreeType='MM' AND NOT EXISTS (SELECT * FROM AD_TreeNodeMM e WHERE e.AD_Tree_ID=t.AD_Tree_ID AND Node_ID=200156)
;
-- July 28, 2021 5:09:28 PM SGT
UPDATE AD_TreeNodeMM SET Parent_ID=326, SeqNo=9, Updated=statement_timestamp() WHERE AD_Tree_ID=10 AND Node_ID=200156
;
-- July 28, 2021 5:15:07 PM SGT
-- AP2-274 Configure Header and Footer for financial reports
INSERT INTO AD_Column (AD_Column_ID,SeqNoSelection,IsSyncDatabase,Version,IsMandatory,IsTranslated,IsIdentifier,SeqNo,IsParent,FieldLength,IsSelectionColumn,IsKey,IsAutocomplete,IsAllowLogging,AD_Column_UU,Updated,IsUpdateable,ColumnName,Name,IsAllowCopy,IsActive,CreatedBy,UpdatedBy,IsAlwaysUpdateable,AD_Client_ID,AD_Org_ID,Created,IsSecure,EntityType,IsEncrypted,FKConstraintType,AD_Element_ID,AD_Table_ID,AD_Reference_ID,IsToolbarButton) VALUES (213521,0,'N',0,'N','N','N',0,'N',22,'N','N','N','Y','6f222c63-afaf-4774-a704-d2437b879cb6',TO_TIMESTAMP('2021-07-28 17:16:57','YYYY-MM-DD HH24:MI:SS'),'N','AD_PrintHeaderFooter_ID','Print Header/Footer','Y','Y',100,100,'N',0,0,TO_TIMESTAMP('2021-07-28 17:16:57','YYYY-MM-DD HH24:MI:SS'),'N','U','N','N',203210,493,19,'N')
;
-- July 28, 2021 5:17:04 PM SGT
INSERT INTO AD_TreeNode (AD_Client_ID,AD_Org_ID, IsActive,Created,CreatedBy,Updated,UpdatedBy, AD_Tree_ID, Node_ID, Parent_ID, SeqNo, AD_TreeNode_UU) SELECT t.AD_Client_ID, 0, 'Y', statement_timestamp(), 100, statement_timestamp(), 100,t.AD_Tree_ID, 200006, 0, 999, Generate_UUID() FROM AD_Tree t WHERE t.AD_Client_ID=0 AND t.IsActive='Y' AND t.IsAllNodes='Y' AND t.TreeType='TL' AND t.AD_Table_ID=282 AND NOT EXISTS (SELECT * FROM AD_TreeNode e WHERE e.AD_Tree_ID=t.AD_Tree_ID AND Node_ID=200006)
;
-- July 28, 2021 5:17:05 PM SGT
UPDATE AD_Column SET FKConstraintType='N', FKConstraintName='ADPrintHeaderFooter_ADPrintFor',Updated=TO_TIMESTAMP('2021-07-28 17:17:05','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Column_ID=213521
;
-- July 28, 2021 5:17:05 PM SGT
ALTER TABLE AD_PrintFormat ADD COLUMN AD_PrintHeaderFooter_ID NUMERIC(10) DEFAULT NULL
;
-- July 28, 2021 5:17:05 PM SGT
ALTER TABLE AD_PrintFormat ADD CONSTRAINT ADPrintHeaderFooter_ADPrintFor FOREIGN KEY (AD_PrintHeaderFooter_ID) REFERENCES ad_printheaderfooter(ad_printheaderfooter_id) DEFERRABLE INITIALLY DEFERRED
;
-- July 28, 2021 5:18:08 PM SGT
INSERT INTO AD_TreeNode (AD_Client_ID,AD_Org_ID, IsActive,Created,CreatedBy,Updated,UpdatedBy, AD_Tree_ID, Node_ID, Parent_ID, SeqNo, AD_TreeNode_UU) SELECT t.AD_Client_ID, 0, 'Y', statement_timestamp(), 100, statement_timestamp(), 100,t.AD_Tree_ID, 200007, 0, 999, Generate_UUID() FROM AD_Tree t WHERE t.AD_Client_ID=0 AND t.IsActive='Y' AND t.IsAllNodes='Y' AND t.TreeType='TL' AND t.AD_Table_ID=282 AND NOT EXISTS (SELECT * FROM AD_TreeNode e WHERE e.AD_Tree_ID=t.AD_Tree_ID AND Node_ID=200007)
;
-- July 28, 2021 5:18:09 PM SGT
INSERT INTO AD_Field (AD_Field_ID,IsEncrypted,DisplayLength,IsSameLine,IsHeading,SeqNo,IsCentrallyMaintained,IsReadOnly,AD_Org_ID,Updated,Name,AD_Field_UU,IsDisplayed,IsFieldOnly,CreatedBy,UpdatedBy,IsActive,IsDisplayedGrid,SeqNoGrid,AD_Client_ID,Created,ColumnSpan,AD_Column_ID,EntityType,AD_Tab_ID) VALUES (205584,'N',22,'N','N',260,'Y','N',0,TO_TIMESTAMP('2021-07-28 17:18:08','YYYY-MM-DD HH24:MI:SS'),'Print Header/Footer','baaa8cef-c923-4a89-b73b-06e6345c2bd4','Y','N',100,100,'Y','Y',260,0,TO_TIMESTAMP('2021-07-28 17:18:08','YYYY-MM-DD HH24:MI:SS'),2,213521,'U',425)
;
-- July 28, 2021 5:18:16 PM SGT
UPDATE AD_Column SET EntityType='D',Updated=TO_TIMESTAMP('2021-07-28 17:18:16','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Column_ID=213521
;
-- July 28, 2021 5:20:18 PM SGT
UPDATE AD_Field SET SeqNo=125, AD_Val_Rule_ID=NULL, SeqNoGrid=125, AD_Reference_Value_ID=NULL, EntityType='D', IsToolbarButton=NULL,Updated=TO_TIMESTAMP('2021-07-28 17:20:18','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Field_ID=205584
;
-- July 28, 2021 5:20:43 PM SGT
UPDATE AD_Field SET DisplayLogic='@IsStandardHeaderFooter@=N', AD_Val_Rule_ID=NULL, AD_Reference_Value_ID=NULL, IsToolbarButton=NULL,Updated=TO_TIMESTAMP('2021-07-28 17:20:43','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Field_ID=205584
;
-- July 28, 2021 5:20:54 PM SGT
UPDATE AD_Field SET AD_Val_Rule_ID=NULL, XPosition=4, AD_Reference_Value_ID=NULL, IsToolbarButton=NULL,Updated=TO_TIMESTAMP('2021-07-28 17:20:54','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Field_ID=205584
;
-- July 28, 2021 5:22:33 PM SGT
UPDATE AD_Column SET IsUpdateable='Y',Updated=TO_TIMESTAMP('2021-07-28 17:22:33','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Column_ID=213521
;
-- Jul 29, 2021, 2:54:24 PM MYT
UPDATE AD_Column SET IsMandatory='Y', SeqNoSelection=10,Updated=TO_TIMESTAMP('2021-07-29 14:54:24','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Column_ID=213520
;
-- Jul 29, 2021, 2:54:29 PM MYT
INSERT INTO t_alter_column values('ad_printheaderfooter','SourceClassName','VARCHAR(255)',null,null)
;
-- Jul 29, 2021, 2:54:29 PM MYT
INSERT INTO t_alter_column values('ad_printheaderfooter','SourceClassName',null,'NOT NULL',null)
;
-- Jul 29, 2021, 2:56:11 PM MYT
INSERT INTO AD_TableIndex (AD_Client_ID,AD_Org_ID,AD_TableIndex_ID,AD_TableIndex_UU,Created,CreatedBy,EntityType,IsActive,Name,Updated,UpdatedBy,AD_Table_ID,IsCreateConstraint,IsUnique,Processing,TableIndexDrop,IsKey) VALUES (0,0,201089,'87fdd27c-eb34-4183-a0e1-92ad668dc7c8',TO_TIMESTAMP('2021-07-29 14:56:10','YYYY-MM-DD HH24:MI:SS'),100,'D','Y','AD_PrintHeaderFooter_Name_Idx',TO_TIMESTAMP('2021-07-29 14:56:10','YYYY-MM-DD HH24:MI:SS'),100,200240,'Y','Y','N','N','N')
;
-- Jul 29, 2021, 2:56:23 PM MYT
INSERT INTO AD_IndexColumn (AD_Client_ID,AD_Org_ID,AD_IndexColumn_ID,AD_IndexColumn_UU,Created,CreatedBy,EntityType,IsActive,Updated,UpdatedBy,AD_Column_ID,AD_TableIndex_ID,SeqNo) VALUES (0,0,201428,'33e8b8f8-cab8-4d3e-a979-473e5226f145',TO_TIMESTAMP('2021-07-29 14:56:23','YYYY-MM-DD HH24:MI:SS'),100,'D','Y',TO_TIMESTAMP('2021-07-29 14:56:23','YYYY-MM-DD HH24:MI:SS'),100,213508,201089,10)
;
-- Jul 29, 2021, 2:56:34 PM MYT
INSERT INTO AD_IndexColumn (AD_Client_ID,AD_Org_ID,AD_IndexColumn_ID,AD_IndexColumn_UU,Created,CreatedBy,EntityType,IsActive,Updated,UpdatedBy,AD_Column_ID,AD_TableIndex_ID,SeqNo) VALUES (0,0,201429,'afa25fab-0832-48cf-bb0e-9ed3fe5c22b3',TO_TIMESTAMP('2021-07-29 14:56:33','YYYY-MM-DD HH24:MI:SS'),100,'D','Y',TO_TIMESTAMP('2021-07-29 14:56:33','YYYY-MM-DD HH24:MI:SS'),100,213517,201089,20)
;
-- Jul 29, 2021, 2:56:40 PM MYT
ALTER TABLE AD_PrintHeaderFooter ADD CONSTRAINT AD_PrintHeaderFooter_Name_Idx UNIQUE (AD_Client_ID,Name)
;
-- Jul 29, 2021, 2:59:52 PM MYT
UPDATE AD_TableIndex SET AD_Message_ID=502,Updated=TO_TIMESTAMP('2021-07-29 14:59:52','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_TableIndex_ID=201089
;
SELECT register_migration_script('202107281652_IDEMPIERE-4894.sql') FROM dual
;

View File

@ -60,6 +60,7 @@ Export-Package: bsh,
org.idempiere.expression.logic, org.idempiere.expression.logic,
org.idempiere.fa.service.api, org.idempiere.fa.service.api,
org.idempiere.model, org.idempiere.model,
org.idempiere.print,
org.idempiere.process org.idempiere.process
Bundle-RequiredExecutionEnvironment: JavaSE-11 Bundle-RequiredExecutionEnvironment: JavaSE-11
Require-Capability: osgi.ee;filter:="(&(osgi.ee=JavaSE)(version>=11))" Require-Capability: osgi.ee;filter:="(&(osgi.ee=JavaSE)(version>=11))"

View File

@ -38,6 +38,7 @@ import org.adempiere.model.MShipperFacade;
import org.compiere.impexp.BankStatementLoaderInterface; import org.compiere.impexp.BankStatementLoaderInterface;
import org.compiere.impexp.BankStatementMatcherInterface; import org.compiere.impexp.BankStatementMatcherInterface;
import org.compiere.model.Callout; import org.compiere.model.Callout;
import org.compiere.model.I_AD_PrintHeaderFooter;
import org.compiere.model.MAddressValidation; import org.compiere.model.MAddressValidation;
import org.compiere.model.MAuthorizationAccount; import org.compiere.model.MAuthorizationAccount;
import org.compiere.model.MBankAccountProcessor; import org.compiere.model.MBankAccountProcessor;
@ -53,6 +54,7 @@ import org.compiere.util.CLogger;
import org.compiere.util.Env; import org.compiere.util.Env;
import org.compiere.util.PaymentExport; import org.compiere.util.PaymentExport;
import org.compiere.util.ReplenishInterface; import org.compiere.util.ReplenishInterface;
import org.compiere.util.Util;
import org.idempiere.distributed.ICacheService; import org.idempiere.distributed.ICacheService;
import org.idempiere.distributed.IClusterService; import org.idempiere.distributed.IClusterService;
import org.idempiere.distributed.IMessageService; import org.idempiere.distributed.IMessageService;
@ -60,6 +62,7 @@ import org.idempiere.fa.service.api.DepreciationFactoryLookupDTO;
import org.idempiere.fa.service.api.IDepreciationMethod; import org.idempiere.fa.service.api.IDepreciationMethod;
import org.idempiere.fa.service.api.IDepreciationMethodFactory; import org.idempiere.fa.service.api.IDepreciationMethodFactory;
import org.idempiere.model.IMappedModelFactory; import org.idempiere.model.IMappedModelFactory;
import org.idempiere.print.IPrintHeaderFooter;
import org.idempiere.process.IMappedProcessFactory; import org.idempiere.process.IMappedProcessFactory;
/** /**
@ -97,6 +100,8 @@ public class Core {
public static final String IPAYMENT_PROCESSOR_FACTORY_CACHE_TABLE_NAME = "_IPaymentProcessorFactory_Cache"; public static final String IPAYMENT_PROCESSOR_FACTORY_CACHE_TABLE_NAME = "_IPaymentProcessorFactory_Cache";
public static final String IPRINT_HEADER_FOOTER_CACHE_TABLE_NAME = "_IIPrintHeaderFooterCache";
private final static CLogger s_log = CLogger.getCLogger(Core.class); private final static CLogger s_log = CLogger.getCLogger(Core.class);
private static final CCache<String, IServiceReferenceHolder<IResourceFinder>> s_resourceFinderCache = new CCache<>(IRESOURCE_FINDER_CACHE_TABLE_NAME, "IResourceFinder", 100, false); private static final CCache<String, IServiceReferenceHolder<IResourceFinder>> s_resourceFinderCache = new CCache<>(IRESOURCE_FINDER_CACHE_TABLE_NAME, "IResourceFinder", 100, false);
@ -1006,4 +1011,40 @@ public class Core {
return null; return null;
} }
private final static CCache<String, IServiceReferenceHolder<IPrintHeaderFooter>> s_printHeaderFooterCache = new CCache<>(IPRINT_HEADER_FOOTER_CACHE_TABLE_NAME, "IPrintHeaderFooterFactory", 100, false);
/**
* Get print header/footer instance
* @param print header/footer
* @return print header/footer instance or null if not found
*/
public static IPrintHeaderFooter getPrintHeaderFooter(I_AD_PrintHeaderFooter printHeaderFooter) {
String componentName = printHeaderFooter.getSourceClassName();
if (Util.isEmpty(componentName, true)) {
s_log.log(Level.SEVERE, "Print Header/Footer source class not defined: " + printHeaderFooter);
return null;
}
IServiceReferenceHolder<IPrintHeaderFooter> cache = s_printHeaderFooterCache.get(componentName);
if (cache != null) {
IPrintHeaderFooter service = cache.getService();
if (service != null) {
return service;
}
s_printHeaderFooterCache.remove(componentName);
}
IServiceReferenceHolder<IPrintHeaderFooter> serviceReference = Service.locator()
.locate(IPrintHeaderFooter.class, componentName, null).getServiceReference();
if (serviceReference == null)
return null;
IPrintHeaderFooter service = serviceReference.getService();
if (service != null) {
s_printHeaderFooterCache.put(componentName, serviceReference);
return service;
}
return null;
}
} }

View File

@ -114,6 +114,17 @@ public interface I_AD_PrintFormat
/** Get AD_PrintFormat_UU */ /** Get AD_PrintFormat_UU */
public String getAD_PrintFormat_UU(); public String getAD_PrintFormat_UU();
/** Column name AD_PrintHeaderFooter_ID */
public static final String COLUMNNAME_AD_PrintHeaderFooter_ID = "AD_PrintHeaderFooter_ID";
/** Set Print Header/Footer */
public void setAD_PrintHeaderFooter_ID (int AD_PrintHeaderFooter_ID);
/** Get Print Header/Footer */
public int getAD_PrintHeaderFooter_ID();
public org.compiere.model.I_AD_PrintHeaderFooter getAD_PrintHeaderFooter() throws RuntimeException;
/** Column name AD_PrintPaper_ID */ /** Column name AD_PrintPaper_ID */
public static final String COLUMNNAME_AD_PrintPaper_ID = "AD_PrintPaper_ID"; public static final String COLUMNNAME_AD_PrintPaper_ID = "AD_PrintPaper_ID";
@ -189,28 +200,6 @@ public interface I_AD_PrintFormat
public org.compiere.model.I_AD_Window getAD_Window() throws RuntimeException; public org.compiere.model.I_AD_Window getAD_Window() throws RuntimeException;
/** Column name Args */
public static final String COLUMNNAME_Args = "Args";
/** Set Args */
public void setArgs (String Args);
/** Get Args */
public String getArgs();
/** Column name Classname */
public static final String COLUMNNAME_Classname = "Classname";
/** Set Classname.
* Java Classname
*/
public void setClassname (String Classname);
/** Get Classname.
* Java Classname
*/
public String getClassname();
/** Column name CreateCopy */ /** Column name CreateCopy */
public static final String COLUMNNAME_CreateCopy = "CreateCopy"; public static final String COLUMNNAME_CreateCopy = "CreateCopy";

View File

@ -0,0 +1,153 @@
/******************************************************************************
* Product: iDempiere ERP & CRM Smart Business Solution *
* Copyright (C) 1999-2012 ComPiere, Inc. All Rights Reserved. *
* This program is free software, you can redistribute it and/or modify it *
* under the terms version 2 of the GNU General Public License as published *
* by the Free Software Foundation. This program is distributed in the hope *
* that it will be useful, but WITHOUT ANY WARRANTY, without even the implied *
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. *
* See the GNU General Public License for more details. *
* You should have received a copy of the GNU General Public License along *
* with this program, if not, write to the Free Software Foundation, Inc., *
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. *
* For the text or an alternative of this public license, you may reach us *
* ComPiere, Inc., 2620 Augustine Dr. #245, Santa Clara, CA 95054, USA *
* or via info@compiere.org or http://www.compiere.org/license.html *
*****************************************************************************/
package org.compiere.model;
import java.math.BigDecimal;
import java.sql.Timestamp;
import org.compiere.util.KeyNamePair;
/** Generated Interface for AD_PrintHeaderFooter
* @author iDempiere (generated)
* @version Release 8.2
*/
public interface I_AD_PrintHeaderFooter
{
/** TableName=AD_PrintHeaderFooter */
public static final String Table_Name = "AD_PrintHeaderFooter";
/** AD_Table_ID=200240 */
public static final int Table_ID = 200240;
KeyNamePair Model = new KeyNamePair(Table_ID, Table_Name);
/** AccessLevel = 4 - System
*/
BigDecimal accessLevel = BigDecimal.valueOf(4);
/** Load Meta Data */
/** Column name AD_Client_ID */
public static final String COLUMNNAME_AD_Client_ID = "AD_Client_ID";
/** Get Client.
* Client/Tenant for this installation.
*/
public int getAD_Client_ID();
/** Column name AD_Org_ID */
public static final String COLUMNNAME_AD_Org_ID = "AD_Org_ID";
/** Set Organization.
* Organizational entity within client
*/
public void setAD_Org_ID (int AD_Org_ID);
/** Get Organization.
* Organizational entity within client
*/
public int getAD_Org_ID();
/** Column name AD_PrintHeaderFooter_ID */
public static final String COLUMNNAME_AD_PrintHeaderFooter_ID = "AD_PrintHeaderFooter_ID";
/** Set Print Header/Footer */
public void setAD_PrintHeaderFooter_ID (int AD_PrintHeaderFooter_ID);
/** Get Print Header/Footer */
public int getAD_PrintHeaderFooter_ID();
/** Column name AD_PrintHeaderFooter_UU */
public static final String COLUMNNAME_AD_PrintHeaderFooter_UU = "AD_PrintHeaderFooter_UU";
/** Set AD_PrintHeaderFooter_UU */
public void setAD_PrintHeaderFooter_UU (String AD_PrintHeaderFooter_UU);
/** Get AD_PrintHeaderFooter_UU */
public String getAD_PrintHeaderFooter_UU();
/** Column name Created */
public static final String COLUMNNAME_Created = "Created";
/** Get Created.
* Date this record was created
*/
public Timestamp getCreated();
/** Column name CreatedBy */
public static final String COLUMNNAME_CreatedBy = "CreatedBy";
/** Get Created By.
* User who created this records
*/
public int getCreatedBy();
/** Column name IsActive */
public static final String COLUMNNAME_IsActive = "IsActive";
/** Set Active.
* The record is active in the system
*/
public void setIsActive (boolean IsActive);
/** Get Active.
* The record is active in the system
*/
public boolean isActive();
/** Column name Name */
public static final String COLUMNNAME_Name = "Name";
/** Set Name.
* Alphanumeric identifier of the entity
*/
public void setName (String Name);
/** Get Name.
* Alphanumeric identifier of the entity
*/
public String getName();
/** Column name SourceClassName */
public static final String COLUMNNAME_SourceClassName = "SourceClassName";
/** Set Source Class.
* Source Class Name
*/
public void setSourceClassName (String SourceClassName);
/** Get Source Class.
* Source Class Name
*/
public String getSourceClassName();
/** Column name Updated */
public static final String COLUMNNAME_Updated = "Updated";
/** Get Updated.
* Date this record was updated
*/
public Timestamp getUpdated();
/** Column name UpdatedBy */
public static final String COLUMNNAME_UpdatedBy = "UpdatedBy";
/** Get Updated By.
* User who updated this records
*/
public int getUpdatedBy();
}

View File

@ -30,7 +30,7 @@ public class X_AD_PrintFormat extends PO implements I_AD_PrintFormat, I_Persiste
/** /**
* *
*/ */
private static final long serialVersionUID = 20201220L; private static final long serialVersionUID = 20210728L;
/** Standard Constructor */ /** Standard Constructor */
public X_AD_PrintFormat (Properties ctx, int AD_PrintFormat_ID, String trxName) public X_AD_PrintFormat (Properties ctx, int AD_PrintFormat_ID, String trxName)
@ -179,6 +179,31 @@ public class X_AD_PrintFormat extends PO implements I_AD_PrintFormat, I_Persiste
return (String)get_Value(COLUMNNAME_AD_PrintFormat_UU); return (String)get_Value(COLUMNNAME_AD_PrintFormat_UU);
} }
public org.compiere.model.I_AD_PrintHeaderFooter getAD_PrintHeaderFooter() throws RuntimeException
{
return (org.compiere.model.I_AD_PrintHeaderFooter)MTable.get(getCtx(), org.compiere.model.I_AD_PrintHeaderFooter.Table_Name)
.getPO(getAD_PrintHeaderFooter_ID(), get_TrxName()); }
/** Set Print Header/Footer.
@param AD_PrintHeaderFooter_ID Print Header/Footer */
public void setAD_PrintHeaderFooter_ID (int AD_PrintHeaderFooter_ID)
{
if (AD_PrintHeaderFooter_ID < 1)
set_Value (COLUMNNAME_AD_PrintHeaderFooter_ID, null);
else
set_Value (COLUMNNAME_AD_PrintHeaderFooter_ID, Integer.valueOf(AD_PrintHeaderFooter_ID));
}
/** Get Print Header/Footer.
@return Print Header/Footer */
public int getAD_PrintHeaderFooter_ID ()
{
Integer ii = (Integer)get_Value(COLUMNNAME_AD_PrintHeaderFooter_ID);
if (ii == null)
return 0;
return ii.intValue();
}
public org.compiere.model.I_AD_PrintPaper getAD_PrintPaper() throws RuntimeException public org.compiere.model.I_AD_PrintPaper getAD_PrintPaper() throws RuntimeException
{ {
return (org.compiere.model.I_AD_PrintPaper)MTable.get(getCtx(), org.compiere.model.I_AD_PrintPaper.Table_Name) return (org.compiere.model.I_AD_PrintPaper)MTable.get(getCtx(), org.compiere.model.I_AD_PrintPaper.Table_Name)
@ -247,9 +272,9 @@ public class X_AD_PrintFormat extends PO implements I_AD_PrintFormat, I_Persiste
public void setAD_ReportView_ID (int AD_ReportView_ID) public void setAD_ReportView_ID (int AD_ReportView_ID)
{ {
if (AD_ReportView_ID < 1) if (AD_ReportView_ID < 1)
set_ValueNoCheck (COLUMNNAME_AD_ReportView_ID, null); set_Value (COLUMNNAME_AD_ReportView_ID, null);
else else
set_ValueNoCheck (COLUMNNAME_AD_ReportView_ID, Integer.valueOf(AD_ReportView_ID)); set_Value (COLUMNNAME_AD_ReportView_ID, Integer.valueOf(AD_ReportView_ID));
} }
/** Get Report View. /** Get Report View.
@ -319,37 +344,6 @@ public class X_AD_PrintFormat extends PO implements I_AD_PrintFormat, I_Persiste
return ii.intValue(); return ii.intValue();
} }
/** Set Args.
@param Args Args */
public void setArgs (String Args)
{
set_Value (COLUMNNAME_Args, Args);
}
/** Get Args.
@return Args */
public String getArgs ()
{
return (String)get_Value(COLUMNNAME_Args);
}
/** Set Classname.
@param Classname
Java Classname
*/
public void setClassname (String Classname)
{
set_Value (COLUMNNAME_Classname, Classname);
}
/** Get Classname.
@return Java Classname
*/
public String getClassname ()
{
return (String)get_Value(COLUMNNAME_Classname);
}
/** Set Create Copy. /** Set Create Copy.
@param CreateCopy Create Copy */ @param CreateCopy Create Copy */
public void setCreateCopy (String CreateCopy) public void setCreateCopy (String CreateCopy)

View File

@ -0,0 +1,149 @@
/******************************************************************************
* Product: iDempiere ERP & CRM Smart Business Solution *
* Copyright (C) 1999-2012 ComPiere, Inc. All Rights Reserved. *
* This program is free software, you can redistribute it and/or modify it *
* under the terms version 2 of the GNU General Public License as published *
* by the Free Software Foundation. This program is distributed in the hope *
* that it will be useful, but WITHOUT ANY WARRANTY, without even the implied *
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. *
* See the GNU General Public License for more details. *
* You should have received a copy of the GNU General Public License along *
* with this program, if not, write to the Free Software Foundation, Inc., *
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. *
* For the text or an alternative of this public license, you may reach us *
* ComPiere, Inc., 2620 Augustine Dr. #245, Santa Clara, CA 95054, USA *
* or via info@compiere.org or http://www.compiere.org/license.html *
*****************************************************************************/
/** Generated Model - DO NOT CHANGE */
package org.compiere.model;
import java.sql.ResultSet;
import java.util.Properties;
import org.compiere.util.KeyNamePair;
/** Generated Model for AD_PrintHeaderFooter
* @author iDempiere (generated)
* @version Release 8.2 - $Id$ */
public class X_AD_PrintHeaderFooter extends PO implements I_AD_PrintHeaderFooter, I_Persistent
{
/**
*
*/
private static final long serialVersionUID = 20210728L;
/** Standard Constructor */
public X_AD_PrintHeaderFooter (Properties ctx, int AD_PrintHeaderFooter_ID, String trxName)
{
super (ctx, AD_PrintHeaderFooter_ID, trxName);
/** if (AD_PrintHeaderFooter_ID == 0)
{
setAD_PrintHeaderFooter_ID (0);
setName (null);
} */
}
/** Load Constructor */
public X_AD_PrintHeaderFooter (Properties ctx, ResultSet rs, String trxName)
{
super (ctx, rs, trxName);
}
/** AccessLevel
* @return 4 - System
*/
protected int get_AccessLevel()
{
return accessLevel.intValue();
}
/** Load Meta Data */
protected POInfo initPO (Properties ctx)
{
POInfo poi = POInfo.getPOInfo (ctx, Table_ID, get_TrxName());
return poi;
}
public String toString()
{
StringBuilder sb = new StringBuilder ("X_AD_PrintHeaderFooter[")
.append(get_ID()).append(",Name=").append(getName()).append("]");
return sb.toString();
}
/** Set Print Header/Footer.
@param AD_PrintHeaderFooter_ID Print Header/Footer */
public void setAD_PrintHeaderFooter_ID (int AD_PrintHeaderFooter_ID)
{
if (AD_PrintHeaderFooter_ID < 1)
set_ValueNoCheck (COLUMNNAME_AD_PrintHeaderFooter_ID, null);
else
set_ValueNoCheck (COLUMNNAME_AD_PrintHeaderFooter_ID, Integer.valueOf(AD_PrintHeaderFooter_ID));
}
/** Get Print Header/Footer.
@return Print Header/Footer */
public int getAD_PrintHeaderFooter_ID ()
{
Integer ii = (Integer)get_Value(COLUMNNAME_AD_PrintHeaderFooter_ID);
if (ii == null)
return 0;
return ii.intValue();
}
/** Set AD_PrintHeaderFooter_UU.
@param AD_PrintHeaderFooter_UU AD_PrintHeaderFooter_UU */
public void setAD_PrintHeaderFooter_UU (String AD_PrintHeaderFooter_UU)
{
set_Value (COLUMNNAME_AD_PrintHeaderFooter_UU, AD_PrintHeaderFooter_UU);
}
/** Get AD_PrintHeaderFooter_UU.
@return AD_PrintHeaderFooter_UU */
public String getAD_PrintHeaderFooter_UU ()
{
return (String)get_Value(COLUMNNAME_AD_PrintHeaderFooter_UU);
}
/** Set Name.
@param Name
Alphanumeric identifier of the entity
*/
public void setName (String Name)
{
set_Value (COLUMNNAME_Name, Name);
}
/** Get Name.
@return Alphanumeric identifier of the entity
*/
public String getName ()
{
return (String)get_Value(COLUMNNAME_Name);
}
/** Get Record ID/ColumnName
@return ID/ColumnName pair
*/
public KeyNamePair getKeyNamePair()
{
return new KeyNamePair(get_ID(), getName());
}
/** Set Source Class.
@param SourceClassName
Source Class Name
*/
public void setSourceClassName (String SourceClassName)
{
set_Value (COLUMNNAME_SourceClassName, SourceClassName);
}
/** Get Source Class.
@return Source Class Name
*/
public String getSourceClassName ()
{
return (String)get_Value(COLUMNNAME_SourceClassName);
}
}

View File

@ -37,7 +37,6 @@ import java.io.Reader;
import java.io.Serializable; import java.io.Serializable;
import java.net.URL; import java.net.URL;
import java.sql.Timestamp; import java.sql.Timestamp;
import java.text.SimpleDateFormat;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
@ -49,9 +48,8 @@ import javax.print.Doc;
import javax.print.DocFlavor; import javax.print.DocFlavor;
import javax.print.attribute.DocAttributeSet; import javax.print.attribute.DocAttributeSet;
import org.compiere.model.MClientInfo; import org.adempiere.base.Core;
import org.compiere.model.MQuery; import org.compiere.model.MQuery;
import org.compiere.model.MSysConfig;
import org.compiere.model.MTable; import org.compiere.model.MTable;
import org.compiere.model.PO; import org.compiere.model.PO;
import org.compiere.model.PrintInfo; import org.compiere.model.PrintInfo;
@ -80,6 +78,8 @@ import org.compiere.util.Msg;
import org.compiere.util.NamePair; import org.compiere.util.NamePair;
import org.compiere.util.Util; import org.compiere.util.Util;
import org.compiere.util.ValueNamePair; import org.compiere.util.ValueNamePair;
import org.idempiere.print.IPrintHeaderFooter;
import org.idempiere.print.StandardHeaderFooter;
/** /**
* Adempiere Print Engine. * Adempiere Print Engine.
@ -265,11 +265,24 @@ public class LayoutEngine implements Pageable, Printable, Doc
boolean tempHasLayout = m_hasLayout; boolean tempHasLayout = m_hasLayout;
m_hasLayout = false; // do not start re-calculation m_hasLayout = false; // do not start re-calculation
MPrintPaper mPaper = MPrintPaper.get(format.getAD_PrintPaper_ID()); MPrintPaper mPaper = MPrintPaper.get(format.getAD_PrintPaper_ID());
if (m_format.isStandardHeaderFooter()) if (m_format.isStandardHeaderFooter()) {
setPaper(mPaper.getCPaper()); StandardHeaderFooter headerFooter = new StandardHeaderFooter();
else setPaper(mPaper.getCPaper(),
headerFooter.getHeaderHeight(), headerFooter.getFooterHeight());
}
else if (m_format.getAD_PrintHeaderFooter_ID() > 0) {
IPrintHeaderFooter printHeaderFooter = Core.getPrintHeaderFooter(m_format.getAD_PrintHeaderFooter());
if (printHeaderFooter != null) {
setPaper(mPaper.getCPaper(),
printHeaderFooter.getHeaderHeight(), printHeaderFooter.getFooterHeight());
} else {
setPaper(mPaper.getCPaper(), setPaper(mPaper.getCPaper(),
m_format.getHeaderMargin(), m_format.getFooterMargin()); m_format.getHeaderMargin(), m_format.getFooterMargin());
}
} else {
setPaper(mPaper.getCPaper(),
m_format.getHeaderMargin(), m_format.getFooterMargin());
}
m_hasLayout = tempHasLayout; m_hasLayout = tempHasLayout;
// //
m_printColor = MPrintColor.get(getCtx(), format.getAD_PrintColor_ID()); m_printColor = MPrintColor.get(getCtx(), format.getAD_PrintColor_ID());
@ -444,8 +457,20 @@ public class LayoutEngine implements Pageable, Printable, Doc
{ {
// Header/Footer // Header/Footer
m_headerFooter = new HeaderFooter(m_printCtx); m_headerFooter = new HeaderFooter(m_printCtx);
if (!m_format.isForm() && m_format.isStandardHeaderFooter()) if (!m_format.isForm()) {
createStandardHeaderFooter(); if (m_format.isStandardHeaderFooter()) {
StandardHeaderFooter headerFooter = new StandardHeaderFooter();
headerFooter.createHeaderFooter(m_format, m_headerFooter, m_header, m_footer, m_query);
} else if (m_format.getAD_PrintHeaderFooter_ID() > 0) {
IPrintHeaderFooter printHeaderFooter = Core.getPrintHeaderFooter(m_format.getAD_PrintHeaderFooter());
if (printHeaderFooter != null) {
printHeaderFooter.createHeaderFooter(m_format, m_headerFooter, m_header, m_footer, m_query);
} else {
if (log.isLoggable(Level.WARNING))
log.warning("Print Header/Footer not found, AD_PrintHeaderFooter_ID="+m_format.getAD_PrintHeaderFooter_ID());
}
}
}
// //
m_pageNo = 0; m_pageNo = 0;
m_pages.clear(); m_pages.clear();
@ -934,77 +959,6 @@ public class LayoutEngine implements Pageable, Printable, Doc
return (getYspace()-height) >= 0f; return (getYspace()-height) >= 0f;
} // isYspaceFor } // isYspaceFor
/**************************************************************************
* Create Standard Header/Footer
* <pre>
* title C Page x of x
* Copyright who date&time
* </pre>
*/
private void createStandardHeaderFooter()
{
MClientInfo ci = MClientInfo.get(Env.getCtx());
PrintElement element = null;
if (ci.getLogoReport_ID() > 0) {
element = new ImageElement(ci.getLogoReport_ID(), false);
} else {
element = new ImageElement(org.compiere.Adempiere.getHeaderLogo());
}
// element = new ImageElement(org.compiere.Adempiere.getImageLogo()); // 100x30
element.layout(48, 15, false, MPrintFormatItem.FIELDALIGNMENTTYPE_LeadingLeft);
element.setLocation(m_header.getLocation());
m_headerFooter.addElement(element);
//
MPrintTableFormat tf = m_format.getTableFormat();
Font font = tf.getPageHeader_Font();
Color color = tf.getPageHeaderFG_Color();
//
element = new StringElement("@*ReportName@", font, color, null, true);
element.layout (m_header.width, 0, true, MPrintFormatItem.FIELDALIGNMENTTYPE_Center);
element.setLocation(m_header.getLocation());
m_headerFooter.addElement(element);
//
//
element = new StringElement("@Page@ @*Page@ @of@ @*PageCount@", font, color, null, true);
element.layout (m_header.width, 0, true, MPrintFormatItem.FIELDALIGNMENTTYPE_TrailingRight);
element.setLocation(m_header.getLocation());
m_headerFooter.addElement(element);
// Footer
font = tf.getPageFooter_Font();
color = tf.getPageFooterFG_Color();
//
element = new StringElement(Env.getStandardReportFooterTrademarkText(), font, color, null, true);
/** You can use the following to customize reports for your product name */
// element = new StringElement(Adempiere.NAME, font, color, null, true);
element.layout (m_footer.width, 0, true, MPrintFormatItem.FIELDALIGNMENTTYPE_LeadingLeft);
Point ft = m_footer.getLocation();
ft.y += m_footer.height - element.getHeight() - 2; // 2pt above min
element.setLocation(ft);
m_headerFooter.addElement(element);
//
String s = MSysConfig.getValue(MSysConfig.ZK_FOOTER_SERVER_MSG, "", Env.getAD_Client_ID(Env.getCtx()));
if (Util.isEmpty(s, true))
s = "@*Header@";
element = new StringElement(s, font, color, null, true);
element.layout (m_footer.width, 0, true, MPrintFormatItem.FIELDALIGNMENTTYPE_Center);
element.setLocation(ft);
m_headerFooter.addElement(element);
//
String timestamp = "";
s = MSysConfig.getValue(MSysConfig.ZK_FOOTER_SERVER_DATETIME_FORMAT, Env.getAD_Client_ID(Env.getCtx()));
if (!Util.isEmpty(s, true))
timestamp = new SimpleDateFormat(s).format(System.currentTimeMillis());
else
timestamp = "@*CurrentDateTime@";
element = new StringElement(timestamp, font, color, null, true);
element.layout (m_footer.width, 0, true, MPrintFormatItem.FIELDALIGNMENTTYPE_TrailingRight);
element.setLocation(ft);
m_headerFooter.addElement(element);
} // createStandardHeaderFooter
/************************************************************************** /**************************************************************************
* Layout Form. * Layout Form.
* For every Row, loop through the Format * For every Row, loop through the Format

View File

@ -0,0 +1,55 @@
/******************************************************************************
* Project: Trek Global ERP *
* Copyright (C) 2009-2018 Trek Global Corporation *
* *
* Product: Adempiere ERP & CRM Smart Business Solution *
* Copyright (C) 1999-2006 ComPiere, Inc. All Rights Reserved. *
* This program is free software; you can redistribute it and/or modify it *
* under the terms version 2 of the GNU General Public License as published *
* by the Free Software Foundation. This program is distributed in the hope *
* that it will be useful, but WITHOUT ANY WARRANTY; without even the implied *
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. *
* See the GNU General Public License for more details. *
* You should have received a copy of the GNU General Public License along *
* with this program; if not, write to the Free Software Foundation, Inc., *
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. *
* For the text or an alternative of this public license, you may reach us *
* ComPiere, Inc., 2620 Augustine Dr. #245, Santa Clara, CA 95054, USA *
* or via info@compiere.org or http://www.compiere.org/license.html *
*****************************************************************************/
package org.idempiere.print;
import java.awt.Rectangle;
import org.compiere.model.MQuery;
import org.compiere.print.MPrintFormat;
import org.compiere.print.layout.HeaderFooter;
/**
* Print header/footer interface
* @author Elaine
*
*/
public interface IPrintHeaderFooter {
/***
*
* @param m_format
* @param m_headerFooter
* @param m_header
* @param m_footer
* @param m_query
*/
public void createHeaderFooter(MPrintFormat m_format, HeaderFooter m_headerFooter, Rectangle m_header, Rectangle m_footer, MQuery m_query);
/**
*
* @return header height
*/
public int getHeaderHeight();
/**
*
* @return footer height
*/
public int getFooterHeight();
}

View File

@ -0,0 +1,124 @@
/******************************************************************************
* Project: Trek Global ERP *
* Copyright (C) 2009-2018 Trek Global Corporation *
* *
* Product: Adempiere ERP & CRM Smart Business Solution *
* Copyright (C) 1999-2006 ComPiere, Inc. All Rights Reserved. *
* This program is free software; you can redistribute it and/or modify it *
* under the terms version 2 of the GNU General Public License as published *
* by the Free Software Foundation. This program is distributed in the hope *
* that it will be useful, but WITHOUT ANY WARRANTY; without even the implied *
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. *
* See the GNU General Public License for more details. *
* You should have received a copy of the GNU General Public License along *
* with this program; if not, write to the Free Software Foundation, Inc., *
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. *
* For the text or an alternative of this public license, you may reach us *
* ComPiere, Inc., 2620 Augustine Dr. #245, Santa Clara, CA 95054, USA *
* or via info@compiere.org or http://www.compiere.org/license.html *
*****************************************************************************/
package org.idempiere.print;
import java.awt.Color;
import java.awt.Font;
import java.awt.Point;
import java.awt.Rectangle;
import java.text.SimpleDateFormat;
import org.compiere.model.MClientInfo;
import org.compiere.model.MQuery;
import org.compiere.model.MSysConfig;
import org.compiere.print.MPrintFormat;
import org.compiere.print.MPrintFormatItem;
import org.compiere.print.MPrintTableFormat;
import org.compiere.print.layout.HeaderFooter;
import org.compiere.print.layout.ImageElement;
import org.compiere.print.layout.PrintElement;
import org.compiere.print.layout.StringElement;
import org.compiere.util.Env;
import org.compiere.util.Util;
/**
*
* @author hengsin
*
*/
public class StandardHeaderFooter implements IPrintHeaderFooter {
/**************************************************************************
* Create Standard Header/Footer
* <pre>
* title C Page x of x
* Copyright who date&time
* </pre>
*/
@Override
public void createHeaderFooter(MPrintFormat m_format, HeaderFooter m_headerFooter, Rectangle m_header, Rectangle m_footer, MQuery m_query)
{
MClientInfo ci = MClientInfo.get(Env.getCtx());
PrintElement element = null;
if (ci.getLogoReport_ID() > 0) {
element = new ImageElement(ci.getLogoReport_ID(), false);
} else {
element = new ImageElement(org.compiere.Adempiere.getHeaderLogo());
}
element.layout(48, 15, false, MPrintFormatItem.FIELDALIGNMENTTYPE_LeadingLeft);
element.setLocation(m_header.getLocation());
m_headerFooter.addElement(element);
//
MPrintTableFormat tf = m_format.getTableFormat();
Font font = tf.getPageHeader_Font();
Color color = tf.getPageHeaderFG_Color();
//
element = new StringElement("@*ReportName@", font, color, null, true);
element.layout (m_header.width, 0, true, MPrintFormatItem.FIELDALIGNMENTTYPE_Center);
element.setLocation(m_header.getLocation());
m_headerFooter.addElement(element);
//
//
element = new StringElement("@Page@ @*Page@ @of@ @*PageCount@", font, color, null, true);
element.layout (m_header.width, 0, true, MPrintFormatItem.FIELDALIGNMENTTYPE_TrailingRight);
element.setLocation(m_header.getLocation());
m_headerFooter.addElement(element);
// Footer
font = tf.getPageFooter_Font();
color = tf.getPageFooterFG_Color();
//
element = new StringElement(Env.getStandardReportFooterTrademarkText(), font, color, null, true);
element.layout (m_footer.width, 0, true, MPrintFormatItem.FIELDALIGNMENTTYPE_LeadingLeft);
Point ft = m_footer.getLocation();
ft.y += m_footer.height - element.getHeight() - 2; // 2pt above min
element.setLocation(ft);
m_headerFooter.addElement(element);
//
String s = MSysConfig.getValue(MSysConfig.ZK_FOOTER_SERVER_MSG, "", Env.getAD_Client_ID(Env.getCtx()));
if (Util.isEmpty(s, true))
s = "@*Header@";
element = new StringElement(s, font, color, null, true);
element.layout (m_footer.width, 0, true, MPrintFormatItem.FIELDALIGNMENTTYPE_Center);
element.setLocation(ft);
m_headerFooter.addElement(element);
//
String timestamp = "";
s = MSysConfig.getValue(MSysConfig.ZK_FOOTER_SERVER_DATETIME_FORMAT, Env.getAD_Client_ID(Env.getCtx()));
if (!Util.isEmpty(s, true))
timestamp = new SimpleDateFormat(s).format(System.currentTimeMillis());
else
timestamp = "@*CurrentDateTime@";
element = new StringElement(timestamp, font, color, null, true);
element.layout (m_footer.width, 0, true, MPrintFormatItem.FIELDALIGNMENTTYPE_TrailingRight);
element.setLocation(ft);
m_headerFooter.addElement(element);
}
@Override
public int getHeaderHeight() {
return 18;
}
@Override
public int getFooterHeight() {
return 18;
}
}

View File

@ -222,7 +222,7 @@ public class WPrintFormatEditor implements ValueChangeListener {
float x = 0; float x = 0;
float y = 0; float y = 0;
if (!(m_printFormat.isForm() && !m_printFormat.isStandardHeaderFooter())) { if (!(m_printFormat.isForm() && !(m_printFormat.isStandardHeaderFooter() || m_printFormat.getAD_PrintHeaderFooter_ID() > 0))) {
pArea[AREA_CONTENT] = new PrintAreaBean(AREA_CONTENT, x, y); pArea[AREA_CONTENT] = new PrintAreaBean(AREA_CONTENT, x, y);
} else { } else {
@ -609,7 +609,7 @@ public class WPrintFormatEditor implements ValueChangeListener {
fieldPosMap.put(pfItem, pos); fieldPosMap.put(pfItem, pos);
} }
if (m_printFormat.isStandardHeaderFooter()) { if (!m_printFormat.isStandardHeaderFooter() && m_printFormat.getAD_PrintHeaderFooter_ID() == 0) {
Absolutechildren line = new Absolutechildren(); Absolutechildren line = new Absolutechildren();
ZKUpdateUtil.setHeight(line, "0px"); ZKUpdateUtil.setHeight(line, "0px");
line.setId("headerMargin"); line.setId("headerMargin");
@ -1170,7 +1170,7 @@ public class WPrintFormatEditor implements ValueChangeListener {
PrintFormatEditorUtil.setY(pfItem, diffY); PrintFormatEditorUtil.setY(pfItem, diffY);
} }
if (m_printFormat.isStandardHeaderFooter()) { if (m_printFormat.isStandardHeaderFooter() || m_printFormat.getAD_PrintHeaderFooter_ID() > 0) {
if (!pfItem.isRelativePosition()) if (!pfItem.isRelativePosition())
PrintFormatEditorUtil.setY(pfItem, ptY - topRef); PrintFormatEditorUtil.setY(pfItem, ptY - topRef);
pfItem.setPrintAreaType(X_AD_PrintFormatItem.PRINTAREATYPE_Content); pfItem.setPrintAreaType(X_AD_PrintFormatItem.PRINTAREATYPE_Content);