how can I change the color of Toast depends on message type in Angular material $mdToast?

后端 未结 9 811
Happy的楠姐
Happy的楠姐 2021-02-03 17:10

While using $mdToast.simple().content(\"some test\") it is showing the toast with black color. how can I change that color to red, yellow and so, depends on the typ

相关标签:
9条回答
  • 2021-02-03 17:41

    There is an easier way by specifying a theme:

    $mdToast.simple().content("some test").theme("success-toast")
    

    And in your CSS:

    md-toast.md-success-toast-theme {
        background-color: green;
        ...
    }
    

    You could incorporate your message type to dynamically select a theme.

    Update: As Charlie Ng pointed out, to avoid warnings regarding use of an unregistered custom theme register it in your module using the theme provider: $mdThemingProvider.theme("success-toast")

    Another update: There was a breaking change created on 2 Dec 2015 (v1.0.0+). You now need to specify:

    md-toast.md-success-toast-theme {
        .md-toast-content {
            background-color: green;
            ...
        }
    }
    
    0 讨论(0)
  • 2021-02-03 17:43

    You can see on this link that you cannot change the background color of the element, it'll be always fixed:

    https://github.com/angular/material/blob/master/src/components/toast/toast-theme.scss

    This is because the Material Design Guidelines for Toasts states that the background will always remains the same:

    https://www.google.com/design/spec/components/snackbars-toasts.html#snackbars-toasts-specs

    Note the background item on the Specs list.

    Nothing is said about the text color in each situation, it's implied that it follows the backgroundPalette, on the '50' hue rotation, declared on that CSS on the GitHub Link.

    The way to distinct a warn toast, or an accent-ted one, from the default, calling an action toast, each with its action button using the appropriate class (md-warn or md-accent).

    $mdToast.show({
        template: '<md-toast>\
            {{ toast.content }}\
            <md-button ng-click="toast.resolve()" class="md-warn">\
                Ok\
            </md-button>\
        </md-toast>',
        controller: [function () {
            this.content = 'Toast Content';
        }],
        controllerAs: 'toast'
    });
    

    The toast itself, which its default form means an action report, with success implied. If it needs more even more attention, force its close by setting up an action button add actions like 'Retry', 'Report a problem', 'Details', which can be used to catch this click and record some technical info, etc... the examples vary from what you need.

    0 讨论(0)
  • 2021-02-03 17:43

    You can do it with factory and some css.

    (function () {
      'use strict';
    
      angular
        .module('app.core')
        .factory('ToastService', ToastService);
    
      /** @ngInject */
      function ToastService($mdToast) {
    
        var service = {
          error: error,
          success: success,
          info : info
        };
    
        return service;
    
        //////////
    
        function success(text) {
          $mdToast.show(
            $mdToast.simple()
              .toastClass("toast-success")
              .textContent(text)
          );
        }
    
        function info(text) {
          $mdToast.show(
            $mdToast.simple()
              .toastClass("toast-info")
              .textContent(text)
          );
        }
    
        function error(text) {
          $mdToast.show(
            $mdToast.simple()
              .toastClass("toast-error")
              .textContent(text)
          );
        }
      }
    }());
    

    And css.

    .toast-error .md-toast-content{
      background-color: rgb(102,187,106) !important;
    }
    
    .toast-info .md-toast-content{
      background-color: rgb(41,182,246) !important;
    }
    
    .toast-error .md-toast-content{
      background-color: rgb(239,83,80) !important;
    }
    
    0 讨论(0)
  • 2021-02-03 17:44

    Just to give another option, $mdToast allows to define toast presets that you can easily instantiate in this way, though i'm struggling to understand how to change the text content, any idea?

    $mdToast.show(
      $mdToast.error()
    );
    

    The presets are defined as explained on https://material.angularjs.org/latest/api/service/$mdToast :

    $mdToastProvider.addPreset('error', {
      options: function() {
        return {
          template:
            '<md-toast>' +
              '<div class="md-toast-content">' +
              '</div>' +
            '</md-toast>',
          position: 'top left',
          hideDelay: 2000,
          toastClass: 'toast-error',
          controllerAs: 'toast',
          bindToController: true
        };
      }
    });
    
    0 讨论(0)
  • 2021-02-03 17:46

    register themes:

    $mdThemingProvider.theme("success-toast");
    $mdThemingProvider.theme("error-toast");
    

    add css:

    md-toast.md-error-toast-theme div.md-toast-content{
        color: white !important;
        background-color: red !important;
    }
    
    md-toast.md-success-toast-theme div.md-toast-content{
        color: white !important;
        background-color: green !important;
    }
    

    use:

    $mdToast.show(
        $mdToast.simple()
            .content(message)
            .hideDelay(2000)
            .position('bottom right')
            .theme(type + "-toast")
    );
    
    0 讨论(0)
  • 2021-02-03 17:51

    One more step to rlay3's answer.

    Angular Material at 0.7.1 added warning to unregistered themes. https://github.com/angular/material/blob/master/CHANGELOG.md#071--2015-01-30

    If theme is not registered, every time the toast shows up, you will be getting a warning message in console like, for example:

    attempted to use unregistered theme 'custom-toast'
    angular.js:12416 Attempted to use unregistered theme 'custom-toast'. 
    Register it with $mdThemingProvider.theme().
    

    To get rid of the warning, you will need to configure the theme 'custom-toast' in your angular app:

    angular.module('myApp', ['ngMaterial'])
    .config(function($mdThemingProvider) {
      $mdThemingProvider.theme('custom-toast')
    });
    

    and use it like:

    $mdToast.simple().content("some test").theme("custom-toast");
    

    references: https://material.angularjs.org/latest/#/Theming/04_multiple_themes

    0 讨论(0)
提交回复
热议问题