Checkbox.js 1.86 KB
import template from "./Checkbox.html";
import style from "antd/lib/checkbox/style/index.css";
angular.module("esNgAntd").directive("antdCheckbox", function (esNgAntd) {
    return {
        controllerAs: "antdCheckbox",
        restrict: "E",
        transclude: true,
        replace: true,
        scope: {
            defaultChecked: "@",
            checked: "@",
            disabled: "@",
            onChange: "&",
        },
        template: template,
        controller: function ($scope, $element, $attrs) {
            this.getContext = function () {
                return $scope;
            };

            $scope.state = {
                checked: $scope.checked || $scope.defaultChecked,
                disabled: false,
            };
            $scope.watch = {
                checked: function (newValue) {
                    if (newValue !== undefined) {
                        $scope.state.checked =
                            newValue === "true" ? true : false;
                    }
                },
                disabled: function (newValue) {
                    if (newValue !== undefined) {
                        $scope.state.disabled =
                            newValue === "true" || newValue === "disabled"
                                ? true
                                : false;
                    }
                },
            };

            for (const key in $scope.watch) {
                $scope.$watch(key, $scope.watch[key], true);
            }

            $scope.handleClick = function ($event) {
                $scope.state.checked = !$scope.state.checked;
                $scope.onChange({
                    event: $event,
                });
            };
        },
        link: function ($scope, $element, $attrs, $controllers, $transclude) {
            esNgAntd.createStyle("ant-checkbox", style);
        },
    };
});