cancel
Showing results for 
Search instead for 
Did you mean: 

How to show the Timeline control in table?

former_member198924
Participant
1) XMLVIEW

	 <Table id="idProductsTable" noDataText="No Data" items="{/}">
            <items>
            <ColumnListItem  counter="0">
            <cells>
            <com:Timeline
			id="idTimeline"
			enableDoubleSided="false"
			groupBy="HireDate"
			growingThreshold="0"
			filterTitle="Job Title"
			sortOldestFirst="true"
			content="{/}"
			axisOrientation="Horizontal"
			alignment="Top"
			showSearch="false"
			showSort="false"
			showHeaderBar="false"
			showSuggestion="false"
			class="timelicss">
		<com:content>
			<com:TimelineItem
			      	id="idTemplateItem"
			      	dateTime="{HireDate}"
			      	status="Success"
			      	title="{Title}"
			      	iconTooltip="{JobTitle}"
					userPicture="{Photo}"
			    	userNameClickable="true"
					text="{JobTitle}"
					userName="{Name}"
					filterValue="{JobTitle}"
					icon="{Icon}">
			</com:TimelineItem>
		</com:content>
	</com:Timeline>
                </cells>
                </ColumnListItem>
                </items>
                <columns>
                    <Column minScreenWidth="Tablet"
				    demandPopin="true" hAlign="Left" >
                        <header>
                            <Text text="" maxLines="0"></Text>
                        </header>
                    </Column>
                </columns>
            </Table>

2) Controller.js

onInit: function () {
			var table1 = this.byId("idProductsTable");
		
    			var datapath= 
				[{"Name":"John","Status":"Success","HireDate": "Date(1471020400000)","JobTitle": "Accounts Payable Manager","JobResponsibilities": "Plans.\"","Photo":"","Icon": "sap-icon://activity-individual"},
        		 {"Name":"Robert","Warning":"Failed","HireDate": "Date(1371020400000)","JobTitle": "Configuration Expert","JobResponsibilities": "I keep the big picture in mind.\"","Photo":"","Icon": "sap-icon://settings"},
    			 {"Name":"Mike","Status":"Warning","HireDate": "Date(1371020400000)","JobTitle": "Credit Analyst","JobResponsibilities": "that’s acceptable for my customers and my company.\"","Photo":"","Icon": "sap-icon://manager-insight"}];
			
		
    		var ojsonModel = new sap.ui.model.json.JSONModel(); 
            ojsonModel.setData(datapath);
            table1.setModel(ojsonModel);


    
    
		}




Hi All,

I need to show the Timeline control (sap.suite.ui.commons.Timeline) in Table (sap.m.table). I have tried that. But duplicate value are repeating. Is it possible to display the Timeline to inside the table?. Can you please assist me.

Accepted Solutions (1)

Accepted Solutions (1)

junwu
Active Contributor
0 Kudos
"property1":"value1""propert2":"value2" you need to put comma in between
former_member198924
Participant
0 Kudos

Thank You Jun Wu

Answers (3)

Answers (3)

former_member198924
Participant
0 Kudos

Hi Mahesh and Jun Wu,

Is it possible to give the color for Timeline box. Can you please suggest me.

maheshpalavalli
Active Contributor

There is a status in timelineitem maybe if you pass it will change the color, never tried though. If not possible you have to use the CSS.

I advice you to close the question and create another question if you get any issues.

BR,

Mahesh

junwu
Active Contributor
0 Kudos

timeline is kind of table, which needs to be bound to array....

so your data model has to support that,

basically you data model should contains array(for the table) which contains array as element (for the timeline)

former_member198924
Participant
0 Kudos

I just want to show the timeline like this. Timeline should come row by row different entries. So please assist me.

former_member198924
Participant
0 Kudos

Hi Jun Wu,

Is it possible to give the color for Timeline box. Can you please suggest me.

maheshpalavalli
Active Contributor
0 Kudos

Hi DURAI VENKATESH,

It is possible but you are doing the binding incorrectly.

1. You mentioned the items binding for the table as items="{/}"

It means it will fetch all array of data that is available in the model.

2. You mentioned the content binding for the timeline as content="{/}"

Which also means fetch all the array of data that is available in the model.

So your code itself is written to show the total no of items available in the model as the table rows and again for every table row, you are again showing the same items for the timelines. So change your data and binding accordingly (both are incorrect).

BR,

Mahesh

former_member198924
Participant
0 Kudos

Hi Mahesh,

Thanks for the reply.

I have binding the model to table in controller itself. So I have removed the items="/" line in table xmlview. When I try to run the code, I'm getting the first row value only in the table. I need to get dynamical values from JSON data. can you please tell me, how to do that. I have mentioned the Table and Timeline control binding.

1) XMLView 
 <Table id="idProductsTable" noDataText="No Data">
            <items>
            <ColumnListItem  counter="0">
            <cells>
            <com:Timeline
			id="idTimeline"
			enableDoubleSided="false"
			groupBy="HireDate"
			growingThreshold="0"
			filterTitle="Job Title"
			sortOldestFirst="true"
			
			axisOrientation="Horizontal"
			alignment="Top"
			showSearch="false"
			showSort="false"
			showHeaderBar="false"
			showSuggestion="false"
			class="timelicss">
		<com:content>
			<com:TimelineItem
			      	id="idTemplateItem"
			      	dateTime="{HireDate}"
			      	status="Success"
			      	title="{Title}"
			      	iconTooltip="{JobTitle}"
					userPicture="{Photo}"
			    	userNameClickable="true"
					text="{JobTitle}"
					userName="{Name}"
					filterValue="{JobTitle}"
					icon="{Icon}">
			</com:TimelineItem>
		</com:content>
	</com:Timeline>
                </cells>
                </ColumnListItem>
                </items>
                <columns>
                    <Column minScreenWidth="Tablet"
				    demandPopin="true" hAlign="Left" >
                        <header>
                            <Text text="" maxLines="0"></Text>
                        </header>
                    </Column>
                </columns>
            </Table>
2) Controller
	onInit: function () {
			var table1 = this.byId("idProductsTable");
			var datapath= [{"Name":"John","Status":"Success","HireDate": "Date(1471020400000)","JobTitle": "Accounts Payable Manager","JobResponsibilities": "Plans.\"","Photo":"","Icon": "sap-icon://activity-individual"}];
        	
	    var ojsonModel = new sap.ui.model.json.JSONModel(); 
            ojsonModel.setData(datapath);
            table1.setModel(ojsonModel);

maheshpalavalli
Active Contributor

Hi DURAI VENKATESH

Like I said, you need to understand the data part correctly first.

Tell me these details.

1. What you want to show in the table, provide the data also

2. What you want to show in the timeline, provide the data

Then I can tell you how to solve your issue.

BR,

Mahesh

former_member198924
Participant
0 Kudos

I want to show dynamic value to timeline. Why I'm using means if i keep timeline to inside the table means I'll get multiple rows and each row have one timeline values. so please assist me.

maheshpalavalli
Active Contributor

Hi Durai,

I understand your question that's why I am asking you please provide me the data for the table and for the timeline. I gave points right, answer to those points.

i will give an example:

[
 {
   "userid":"user1",
   "name":"Test user 1",
   "timeline":[{
      "property1":"value1"
      "propert2":"value2"
     },{
      "property1":"value1"
      "propert2":"value2"
    }]
 },
{
   "userid":"user2",
   "name":"Test user 2",
   "timeline":[{
      "property1":"value1"
      "propert2":"value2"
     },{
      "property1":"value1"
      "propert2":"value2"
    }]
 }
]

If you have the data in the above format, then you can bind the table with items="{/}" and timeline content with content="{timeline}", this will work. But the data you have given is not in the correct format. That is why I am asking you to understand what you want to do first.

BR,

Mahesh

former_member198924
Participant
0 Kudos

Hi Mahesh,

When I try to define the Json data, I'm getting the following error message "error: ESLINT: Parsing error: Unexpected token "propert2"".

Can you please assist me.

  var jsonData = [
 {
   "userid":"user1",
   "name":"Test user 1",
   "timeline":[{
      "property1":"value1"
      "propert2":"value2"
     },{
      "property1":"value1"
      "propert2":"value2"
    }]
 },
{
   "userid":"user2",
   "name":"Test user 2",
   "timeline":[{
      "property1":"value1"
      "propert2":"value2"
     },{
      "property1":"value1"
      "propert2":"value2"
    }]
 }
];

maheshpalavalli
Active Contributor

😄 Jun Wu is right, you need to give commas, I just pasted a dummy code..

former_member198924
Participant
0 Kudos

Hi Mahesh,

Thank you so much for your suggestion. I have modified the json data based on your suggestion. It is working fine.

former_member198924
Participant
0 Kudos

Hi Mahesh,

Is it possible to add some colour into the boxes as seen in the image below. Can you please suggest me.