Focal Point
[CASE-NEVER-OPENED] Strange WebFOCUS styling issues

This topic can be found at:
https://forums.informationbuilders.com/eve/forums/a/tpc/f/7971057331/m/9287015436

November 04, 2013, 03:28 PM
Francis Mariani
[CASE-NEVER-OPENED] Strange WebFOCUS styling issues
1) I would like to conditionally modify the font colour of data rows.

2) I also would like to set the column width of certain columns.

Doing these two in the same report is causing me problems:

1) The data row conditional colour does not work on columns where WRAP is specified - for both Excel and HTML.

2) Commenting-out the data row background colour makes the numeric columns left-justified - for HTML, the justification problem is not an issue in Excel.

-SET &ECHO=ALL;

-SET &WFFMT='HTML';
-*-SET &WFFMT='EXL2K';

SET PAGE=NOLEAD
SET HTMLCSS=ON
SET BYDISPLAY=ON

DEFINE FILE CAR
COL_FLAG/A1 = IF COUNTRY EQ 'ITALY' THEN 'Y' ELSE 'N';
END

TABLE FILE CAR
SUM
WARRANTY
STANDARD
HEIGHT    AS 'A LONG COLUMN TITLE FOR HEIGHT'
WEIGHT    AS 'A LONG COLUMN TITLE FOR WEIGHT'
LENGTH    AS 'A LONG COLUMN TITLE FOR LENGTH'
WIDTH
SALES
FUEL_CAP  AS 'FUEL CAP'
BHP       AS 'BRUTE HORSEPOWER'
COL_FLAG

BY COUNTRY AS 'COUNTRY'
BY CAR AS 'CAR'

ON TABLE SET STYLE *

TYPE=DATA, BACKCOLOR=(WHITE SILVER), $
TYPE=DATA, COLOR=RED, WHEN=COL_FLAG EQ 'Y', $

TYPE=REPORT, COLUMN=COUNTRY, WRAP=OFF, $
TYPE=REPORT, COLUMN=WARRANTY, WRAP=OFF, $
TYPE=REPORT, COLUMN=WEIGHT, WRAP=80, $
TYPE=REPORT, COLUMN=HEIGHT, WRAP=80, $
TYPE=REPORT, COLUMN=LENGTH, WRAP=80, $
ENDSTYLE

ON TABLE PCHOLD FORMAT &WFFMT
END

This message has been edited. Last edited by: Francis Mariani,


Francis


Give me code, or give me retirement. In FOCUS since 1991

Production: WF 7.7.05M, Dev Studio, BID, MRE, WebSphere, DB2 / Test: WF 8.1.05M, App Studio, BI Portal, Report Caster, jQuery, HighCharts, Apache Tomcat, MS SQL Server
November 05, 2013, 05:06 AM
Danny-SRL
Francis,
I think your TYPE=REPORT overrides your TYPE=DATA.


Daniel
In Focus since 1982
wf 8.202M/Win10/IIS/SSA - WrapApp Front End for WF

November 05, 2013, 06:55 AM
Tony A
This is the line that is causing the issue (I think) as it appears to be the last styling applied -
TYPE=DATA, BACKCOLOR=(WHITE SILVER), $

T



In FOCUS
since 1986
WebFOCUS Server 8.2.01M, thru 8.2.07 on Windows Svr 2008 R2  
WebFOCUS App Studio 8.2.06 standalone on Windows 10 
November 05, 2013, 11:17 AM
Francis Mariani
I guess WebFOCUS styling isn't cascading, though TYPE=DATA shouldn't override TYPE=REPORT. I've opened a case, will update here...


Francis


Give me code, or give me retirement. In FOCUS since 1991

Production: WF 7.7.05M, Dev Studio, BID, MRE, WebSphere, DB2 / Test: WF 8.1.05M, App Studio, BI Portal, Report Caster, jQuery, HighCharts, Apache Tomcat, MS SQL Server
August 01, 2014, 05:32 AM
SWES
I'm having an exact same situation here, TYPE=REPORT overriding TYPE=DATA, has something come up by now or is there a work around maybe?

Thanks,
SWES


WebFOCUS 8105m
Windows 7, All Outputs

Member of the Benelux Usergroup
August 01, 2014, 02:09 PM
Francis Mariani
It seems the only workaround is to repeat the styling for the columns where other styling is specified:

-SET &ECHO=ALL;

-SET &WFFMT='HTML';
-*-SET &WFFMT='EXL2K';

SET PAGE=NOLEAD
SET HTMLCSS=ON
SET BYDISPLAY=ON

DEFINE FILE CAR
COL_FLAG/A1 = IF COUNTRY EQ 'ITALY' THEN 'Y' ELSE 'N';
END

TABLE FILE CAR
SUM
WARRANTY
STANDARD
HEIGHT    AS 'A LONG COLUMN TITLE FOR HEIGHT'
WEIGHT    AS 'A LONG COLUMN TITLE FOR WEIGHT'
LENGTH    AS 'A LONG COLUMN TITLE FOR LENGTH'
WIDTH
SALES
FUEL_CAP  AS 'FUEL CAP'
BHP       AS 'BRUTE HORSEPOWER'
COL_FLAG

BY COUNTRY AS 'COUNTRY'
BY CAR AS 'CAR'

ON TABLE SET STYLE *

TYPE=DATA, BACKCOLOR=(WHITE SILVER), $
TYPE=DATA, COLOR=RED, WHEN=COL_FLAG EQ 'Y', $
TYPE=DATA, COLUMN=COUNTRY, COLOR=RED, WHEN=COL_FLAG EQ 'Y', $
TYPE=DATA, COLUMN=WARRANTY, COLOR=RED, WHEN=COL_FLAG EQ 'Y', $
TYPE=DATA, COLUMN=HEIGHT, COLOR=RED, WHEN=COL_FLAG EQ 'Y', $
TYPE=DATA, COLUMN=WEIGHT, COLOR=RED, WHEN=COL_FLAG EQ 'Y', $
TYPE=DATA, COLUMN=LENGTH, COLOR=RED, WHEN=COL_FLAG EQ 'Y', $

TYPE=REPORT, COLUMN=COUNTRY, WRAP=OFF, $
TYPE=REPORT, COLUMN=WARRANTY, WRAP=OFF, $
TYPE=REPORT, COLUMN=WEIGHT, WRAP=80, $
TYPE=REPORT, COLUMN=HEIGHT, WRAP=80, $
TYPE=REPORT, COLUMN=LENGTH, WRAP=80, $
ENDSTYLE

ON TABLE PCHOLD FORMAT &WFFMT
END



Francis


Give me code, or give me retirement. In FOCUS since 1991

Production: WF 7.7.05M, Dev Studio, BID, MRE, WebSphere, DB2 / Test: WF 8.1.05M, App Studio, BI Portal, Report Caster, jQuery, HighCharts, Apache Tomcat, MS SQL Server
August 05, 2014, 11:40 AM
SWES
Got it Francis, but the only matter I have is that I need to wrap a column for a PDF output and can't figure how to combine it with specifying it twice?


 $
TYPE=REPORT,
     COLUMN=NAME,
	 WRAP=3.00000,
$
TYPE = DATA, BACKCOLOR = RGB(215 235 194), WHEN = FLAG EQ 1,$
TYPE = DATA, BACKCOLOR = RGB(255 255 255), WHEN = FLAG EQ 2,$


This won't work:

 $
TYPE=DATA,
     COLUMN=NAME,
	 WRAP=3.00000,
$
TYPE = DATA, BACKCOLOR = RGB(215 235 194), WHEN = FLAG EQ 1,$
TYPE = DATA, BACKCOLOR = RGB(255 255 255), WHEN = FLAG EQ 2,$


This won't work either:

 $
$
TYPE=REPORT,
     COLUMN=NAME,
	 WRAP=3.00000,
	 BACKCOLOR = RGB(215 235 194), WHEN = FLAG EQ 1,$
$
TYPE=REPORT,
     COLUMN=NAME,
	 WRAP=3.00000,
	 BACKCOLOR = RGB(255 255 255), WHEN = FLAG EQ 2,
$
TYPE = DATA, BACKCOLOR = RGB(215 235 194), WHEN = FLAG EQ 1,$
TYPE = DATA, BACKCOLOR = RGB(255 255 255), WHEN = FLAG EQ 2,$



WebFOCUS 8105m
Windows 7, All Outputs

Member of the Benelux Usergroup
August 05, 2014, 12:13 PM
eric.woerle
SWES, what if you flip the order of your Style Commands. Since Style Sheets read top down and it seems that the TYPE=DATA command is removing your WRAP command maybe having the below will work better. Also why are you issuing TYPE=REPORT? I would just have used TYPE=DATA, and then if needed I would set my TYPE=HEADING for the specific column.

$

TYPE = DATA, BACKCOLOR = RGB(215 235 194), WHEN = FLAG EQ 1,$
TYPE = DATA, BACKCOLOR = RGB(255 255 255), WHEN = FLAG EQ 2,$

TYPE=REPORT,
     COLUMN=NAME,
	 WRAP=3.00000,
	 BACKCOLOR = RGB(215 235 194), WHEN = FLAG EQ 1,$
$
TYPE=REPORT,
     COLUMN=NAME,
	 WRAP=3.00000,
	 BACKCOLOR = RGB(255 255 255), WHEN = FLAG EQ 2,
$
  



Eric Woerle
8.1.05M Gen 913- Reporting Server Unix
8.1.05 Client Unix
Oracle 11.2.0.2
August 06, 2014, 02:26 AM
SWES
Thank you for your reply Eric. Changing the order is what I tried before, what happens is that the WRAP command doesn't work anymore. What do you mean by changing to TYPE=HEADING?

 $
TYPE = DATA, BACKCOLOR = RGB(215 235 194), WHEN = FLAG EQ 1,$
TYPE = DATA, BACKCOLOR = RGB(255 255 255), WHEN = FLAG EQ 2,$

TYPE=HEADING,
     COLUMN=CLIENTNAME,
	 WRAP=3.00000,
	 BACKCOLOR = RGB(215 235 194), WHEN = FLAG EQ 1,$
$
TYPE=HEADING,
     COLUMN=CLIENTNAME,
	 WRAP=3.00000,
	 BACKCOLOR = RGB(255 255 255), WHEN = FLAG EQ 2,
$ 


Like this?

Thanks,
SWES


WebFOCUS 8105m
Windows 7, All Outputs

Member of the Benelux Usergroup