| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101 |
- define(['jquery', 'bootstrap', 'backend', 'table', 'form', 'template'], function ($, undefined, Backend, Table, Form, Template) {
- var Controller = {
- index: function () {
- // 初始化表格参数配置
- Table.api.init({
- extend: {
- index_url: 'config/userlevel/index' + location.search,
- add_url: 'config/userlevel/add',
- edit_url: 'config/userlevel/edit',
- del_url: 'config/userlevel/del',
- multi_url: 'config/userlevel/multi',
- table: 'user_level',
- }
- });
- var table = $("#table");
- // 初始化表格
- table.bootstrapTable({
- url: $.fn.bootstrapTable.defaults.extend.index_url,
- pk: 'id',
- sortName: 'id',
- columns: [
- [
- {checkbox: true},
- {field: 'id', title: __('Id')},
- {field: 'name', title: __('Name')},
- {field: 'icon', title: __('Icon'), formatter: Controller.api.formatter.icon},
- {field: 'status', title: __('Status'), formatter: Table.api.formatter.toggle},
- {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
- ]
- ]
- });
- // 为表格绑定事件
- Table.api.bindevent(table);
- },
- add: function () {
- Controller.api.bindevent();
- },
- edit: function () {
- Controller.api.bindevent();
- },
- api: {
- formatter: {
- title: function (value, row, index) {
- return !row.ismenu || row.status == 'hidden' ? "<span class='text-muted'>" + value + "</span>" : value;
- },
- name: function (value, row, index) {
- return !row.ismenu || row.status == 'hidden' ? "<span class='text-muted'>" + value + "</span>" : value;
- },
- icon: function (value, row, index) {
- return '<span class="' + (!row.ismenu || row.status == 'hidden' ? 'text-muted' : '') + '"><i class="' + value + '"></i></span>';
- },
- subnode: function (value, row, index) {
- return '<a href="javascript:;" data-toggle="tooltip" title="' + __('Toggle sub menu') + '" data-id="' + row.id + '" data-pid="' + row.pid + '" class="btn btn-xs '
- + (row.haschild == 1 || row.ismenu == 1 ? 'btn-success' : 'btn-default disabled') + ' btn-node-sub"><i class="fa fa-sitemap"></i></a>';
- }
- },
- bindevent: function () {
- var iconlist = [];
- var iconfunc = function () {
- Layer.open({
- type: 1,
- area: ['99%', '98%'], //宽高
- content: Template('chooseicontpl', {iconlist: iconlist})
- });
- };
- Form.api.bindevent($("form[role=form]"), function (data) {
- Fast.api.refreshmenu();
- });
- $(document).on('click', ".btn-search-icon", function () {
- if (iconlist.length == 0) {
- $.get(Config.site.cdnurl + "/assets/libs/font-awesome/less/variables.less", function (ret) {
- var exp = /fa-var-(.*):/ig;
- var result;
- while ((result = exp.exec(ret)) != null) {
- iconlist.push(result[1]);
- }
- iconfunc();
- });
- } else {
- iconfunc();
- }
- });
- $(document).on('click', '#chooseicon ul li', function () {
- $("input[name='row[icon]']").val('fa fa-' + $(this).data("font"));
- Layer.closeAll();
- });
- $(document).on('keyup', 'input.js-icon-search', function () {
- $("#chooseicon ul li").show();
- if ($(this).val() != '') {
- $("#chooseicon ul li:not([data-font*='" + $(this).val() + "'])").hide();
- }
- });
- }
- }
- };
- return Controller;
- });
|