I have code like this:
$stateProvider
  .state('managementPanels-show', {
    url: '/management-panels/show/:id',
    template: '<mp-show></mp-show>',
    data: {},
    resolve: {}
  });
how can I add :id to the template?
You cannot directly access the :id in template. You need to inject the $stateParams service in your controller and expose the :id property on controller $scope
.controller('YourController', function ($scope, $stateParams){
   $scope.id = $stateParams.id;
})
In your template now you can access id as:
$stateProvider
  .state('managementPanels-show', {
    url: '/management-panels/show/:id',
    template: '<mp-show>{{id}}</mp-show>',
    controller: 'YourController',
    data: {},
    resolve: {}
  });
If you plan to integrate $state and $stateParams often in your templates, it might be useful to add it assign it to $scope or $rootScope. See the following example from the Docs:
angular.module("myApp").run(function ($rootScope, $state, $stateParams) {
    $rootScope.$state = $state;
    $rootScope.$stateParams = $stateParams;
});
Now you can interpolate data values on $scope and $rootScope using Angular's double curly bracket notation.
Config:
$stateProvider
    .state('content', {
        url: "/",
        data: {
            title: 'test'
        }
    })
Template:
{{ $state.current.data.title }}
Source: https://github.com/angular-ui/ui-router/wiki/quick-reference#note-about-using-state-within-a-template
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With