From be6869a87e0bdf02fa7ed753d9d32c7af6c1608c Mon Sep 17 00:00:00 2001 From: baozhoutao Date: Thu, 9 May 2024 15:14:05 +0800 Subject: [PATCH] build creator --- .../programs/server/packages/modules.js | 26 +++++++++---------- .../server/packages/steedos_objects.js | 11 ++++++-- .../server/packages/steedos_objects.js.map | 2 +- ...d6afbfa6d571fa8e0eb86d000d02178fdf01c3.js} | 16 ++++++------ ...d571fa8e0eb86d000d02178fdf01c3.stats.json} | 24 ++++++++--------- .../programs/web.browser.legacy/program.json | 22 ++++++++-------- ...d6afbfa6d571fa8e0eb86d000d02178fdf01c3.js} | 16 ++++++------ ...d571fa8e0eb86d000d02178fdf01c3.stats.json} | 24 ++++++++--------- .../bundle/programs/web.browser/program.json | 22 ++++++++-------- ...2ba9e3da8c7d7570f1cffd7ec10e272010cd34.js} | 14 +++++----- ...8c7d7570f1cffd7ec10e272010cd34.stats.json} | 24 ++++++++--------- .../bundle/programs/web.cordova/program.json | 26 +++++++++---------- server/bundle/star.json | 2 +- 13 files changed, 118 insertions(+), 111 deletions(-) rename server/bundle/programs/web.browser.legacy/{0e8e091408993e566bde6016e2c1649202635d18.js => 46d6afbfa6d571fa8e0eb86d000d02178fdf01c3.js} (87%) rename server/bundle/programs/web.browser.legacy/{0e8e091408993e566bde6016e2c1649202635d18.stats.json => 46d6afbfa6d571fa8e0eb86d000d02178fdf01c3.stats.json} (99%) rename server/bundle/programs/web.browser/{0e8e091408993e566bde6016e2c1649202635d18.js => 46d6afbfa6d571fa8e0eb86d000d02178fdf01c3.js} (87%) rename server/bundle/programs/web.browser/{0e8e091408993e566bde6016e2c1649202635d18.stats.json => 46d6afbfa6d571fa8e0eb86d000d02178fdf01c3.stats.json} (99%) rename server/bundle/programs/web.cordova/{9f30c101caa5703f6bfb61789c7e2d80336dd6dc.js => c22ba9e3da8c7d7570f1cffd7ec10e272010cd34.js} (88%) rename server/bundle/programs/web.cordova/{9f30c101caa5703f6bfb61789c7e2d80336dd6dc.stats.json => c22ba9e3da8c7d7570f1cffd7ec10e272010cd34.stats.json} (99%) diff --git a/server/bundle/programs/server/packages/modules.js b/server/bundle/programs/server/packages/modules.js index 0f313ac539..80d0ac2814 100644 --- a/server/bundle/programs/server/packages/modules.js +++ b/server/bundle/programs/server/packages/modules.js @@ -463,7 +463,7 @@ module.useNode(); // module.exports = { "name": "@steedos/objectql", - "version": "2.6.11-beta.5", + "version": "2.6.11", "main": "lib/index.js" }; @@ -490,7 +490,7 @@ module.useNode(); // module.exports = { "name": "@steedos/i18n", - "version": "2.6.11-beta.5", + "version": "2.6.11", "main": "lib/index.js" }; @@ -517,7 +517,7 @@ module.useNode(); // module.exports = { "name": "@steedos/core", - "version": "2.6.11-beta.5", + "version": "2.6.11", "main": "lib/index.js" }; @@ -544,7 +544,7 @@ module.useNode(); // module.exports = { "name": "@steedos/service-meteor-package-loader", - "version": "2.6.11-beta.5", + "version": "2.6.11", "main": "index.js" }; @@ -571,7 +571,7 @@ module.useNode(); // module.exports = { "name": "@steedos/service-api", - "version": "2.6.11-beta.5", + "version": "2.6.11", "main": "index.js" }; @@ -598,7 +598,7 @@ module.useNode(); // module.exports = { "name": "@steedos/service-metadata-server", - "version": "2.6.11-beta.5", + "version": "2.6.11", "main": "index.js" }; @@ -625,7 +625,7 @@ module.useNode(); // module.exports = { "name": "@steedos/service-package-registry", - "version": "2.6.11-beta.5", + "version": "2.6.11", "main": "package.service.js" }; @@ -652,7 +652,7 @@ module.useNode(); // module.exports = { "name": "@steedos/service-objectql", - "version": "2.6.11-beta.5", + "version": "2.6.11", "main": "package.service.js" }; @@ -679,7 +679,7 @@ module.useNode(); // module.exports = { "name": "@steedos/service-ui", - "version": "2.6.11-beta.5", + "version": "2.6.11", "main": "package.service.js" }; @@ -706,7 +706,7 @@ module.useNode(); // module.exports = { "name": "@steedos/service-pages", - "version": "2.6.11-beta.5", + "version": "2.6.11", "main": "package.service.js" }; @@ -733,7 +733,7 @@ module.useNode(); // module.exports = { "name": "@steedos/router", - "version": "2.6.11-beta.5", + "version": "2.6.11", "main": "lib/index.js" }; @@ -760,7 +760,7 @@ module.useNode(); // module.exports = { "name": "@steedos/auth", - "version": "2.6.11-beta.5", + "version": "2.6.11", "main": "lib/index.js" }; @@ -787,7 +787,7 @@ module.useNode(); // module.exports = { "name": "@steedos/workflow", - "version": "2.6.11-beta.5", + "version": "2.6.11", "main": "index.js" }; diff --git a/server/bundle/programs/server/packages/steedos_objects.js b/server/bundle/programs/server/packages/steedos_objects.js index e0b829a5e7..e86d2e9ba0 100644 --- a/server/bundle/programs/server/packages/steedos_objects.js +++ b/server/bundle/programs/server/packages/steedos_objects.js @@ -451,7 +451,14 @@ Creator.getOrderlySetByIds = function (docs, ids, id_key, hit_first) { }); } else { return _.sortBy(docs, function (doc) { - return ids.indexOf(doc[id_key]); + var v; + v = ids.indexOf(doc[id_key]); + + if (v < 0) { + return 99999; + } else { + return v; + } }); } }; /* @@ -5679,4 +5686,4 @@ Package._define("steedos:objects"); })(); //# sourceURL=meteor://💻app/packages/steedos_objects.js -//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["meteor://💻app/packages/steedos_objects/core.coffee","meteor://💻app/core.coffee","meteor://💻app/packages/steedos_objects/loadStandardObjects.coffee","meteor://💻app/loadStandardObjects.coffee","meteor://💻app/packages/steedos_objects/coreSupport.coffee","meteor://💻app/coreSupport.coffee","meteor://💻app/packages/steedos_objects/server/methods/object_options.coffee","meteor://💻app/server/methods/object_options.coffee","meteor://💻app/packages/steedos_objects/lib/listviews.coffee","meteor://💻app/lib/listviews.coffee","meteor://💻app/packages/steedos_objects/lib/add_simple_schema_validation_error.coffee","meteor://💻app/lib/add_simple_schema_validation_error.coffee","meteor://💻app/packages/steedos_objects/lib/field_simple_schema_validation_error.coffee","meteor://💻app/lib/field_simple_schema_validation_error.coffee","meteor://💻app/packages/steedos:objects/lib/eval.js","meteor://💻app/packages/steedos_objects/lib/convert.coffee","meteor://💻app/lib/convert.coffee","meteor://💻app/packages/steedos_objects/lib/formular.coffee","meteor://💻app/lib/formular.coffee","meteor://💻app/packages/steedos_objects/lib/object.coffee","meteor://💻app/lib/object.coffee","meteor://💻app/packages/steedos_objects/lib/fields.coffee","meteor://💻app/lib/fields.coffee","meteor://💻app/packages/steedos_objects/lib/triggers.coffee","meteor://💻app/lib/triggers.coffee","meteor://💻app/packages/steedos_objects/lib/permission_sets.coffee","meteor://💻app/lib/permission_sets.coffee","meteor://💻app/packages/steedos_objects/lib/collections.coffee","meteor://💻app/lib/collections.coffee","meteor://💻app/packages/steedos_objects/lib/actions.coffee","meteor://💻app/lib/actions.coffee"],"names":["db","Creator","Objects","Collections","Menus","Apps","Dashboards","Reports","subs","steedosSchema","APIService","MetadataService","config","e","moleculer","objectql","packageLoader","packageService","path","settings","steedosCore","process","env","CREATOR_NODE_ENV","require","getSteedosConfig","built_in_plugins","plugins","Meteor","startup","apiService","broker","ex","metadataService","objectqlService","pageService","projectService","standardObjectsDir","standardObjectsPackageLoaderService","steedosService","uiService","ServiceBroker","namespace","nodeID","metadata","transporter","TRANSPORTER","cacher","CACHER","logLevel","serializer","requestTimeout","maxCallLevel","heartbeatInterval","heartbeatTimeout","contextParamsCloning","tracking","enabled","shutdownTimeout","disableBalancer","registry","strategy","preferLocal","bulkhead","concurrency","maxQueueSize","validator","errorHandler","tracing","exporter","type","options","logger","colors","width","gaugeWidth","skipProcessEventRegistration","created","warn","clean","init","createService","name","mixins","port","started","setTimeout","emit","getSteedosSchema","StandardObjectsPath","packageInfo","wrapAsync","cb","start","then","connectHandlersExpress","express","_restartService","use","staticRouter","waitForServices","console","log","SteedosApi","WebApp","connectHandlers","resolve","reject","error","Fiber","deps","app","Tracker","Dependency","object","_TEMPLATE","SimpleSchema","extendOptions","filtersFunction","Match","Optional","OneOf","Function","String","optionsFunction","createFunction","isServer","fiberLoadObjects","obj","object_name","loadObjects","run","list_views","space","getCollectionName","_","clone","convertObject","Object","initTriggers","initListViews","getObjectName","getObject","space_id","ref","ref1","isArray","isClient","depend","Session","get","objectsByName","getObjectById","object_id","findWhere","_id","removeObject","getCollection","spaceId","_collection_name","removeCollection","isSpaceAdmin","userId","findOne","fields","admins","indexOf","evaluateFormula","formular","context","isString","Formular","checkFormula","evaluateFilters","filters","selector","each","filter","action","value","length","isCommonSpace","getOrderlySetByIds","docs","ids","id_key","hit_first","values","getProperty","sortBy","doc","_index","sortingMethod","value1","value2","isValue1Empty","isValue2Empty","locale","key","Date","getTime","Steedos","toString","localeCompare","getObjectRelateds","_object","permissions","relatedList","relatedListMap","related_objects","isEmpty","objName","isObject","objectName","related_object","related_object_name","related_field","related_field_name","reference_to","foreign_key","write_requires_master_read","enableObjName","getPermissions","enable_audit","modifyAllRecords","enable_files","push","sfsFilesObject","splice","enable_tasks","enable_notes","enable_events","enable_instances","enable_approvals","enable_process","getUserContext","isUnSafeMode","USER_CONTEXT","space_user_org","su","suFields","Error","mobile","position","email","company","organization","company_id","company_ids","user","fullname","getRelativeUrl","url","isFunction","isCordova","startsWith","test","__meteor_runtime_config__","ROOT_URL_PATH_PREFIX","getUserCompanyId","getUserCompanyIds","processPermissions","po","allowCreate","allowRead","allowEdit","allowDelete","viewAllRecords","viewCompanyRecords","modifyCompanyRecords","allowReadFiles","viewAllFiles","allowCreateFiles","allowEditFiles","allowDeleteFiles","modifyAllFiles","getTemplateSpaceId","templateSpaceId","getCloudAdminSpaceId","cloudAdminSpaceId","isTemplateSpace","isCloudAdminSpace","steedosStorageDir","STEEDOS_STORAGE_DIR","methods","collection","name_field_key","options_limit","query","query_options","records","results","searchTextQuery","selected","sort","params","NAME_FIELD_KEY","searchText","$regex","$or","$in","extend","$nin","filterQuery","limit","find","fetch","record","label","message","JSON","stringify","getInitWidthPercent","columns","_schema","column_num","init_width_percent","getSchema","field_name","field","is_wide","ref2","pick","autoform","getFieldIsWide","getTabularOrder","list_view_id","setting","record_id","map","column","hidden","compact","order","index","default_extra_columns","extra_columns","getObjectDefaultColumns","getObjectDefaultExtraColumns","union","getObjectDefaultSort","TabularSelectedIds","convertListView","default_view","list_view","list_view_name","default_columns","default_mobile_columns","oitem","mobile_columns","has","include","filter_scope","parse","forEach","_value","getRelatedList","layoutRelatedList","list","mapList","objectLayoutRelatedListObjects","relatedListNames","relatedListObjects","related_object_names","unrelated_objects","related_lists","item","reFieldName","reObjectName","related","related_field_fullname","split","field_names","is_file","customRelatedListObject","actions","buttons","visible_on","page_size","objOrName","getRelatedObjects","related_object_item","relatedObject","tabular_order","getObjectFirstListViewColumns","without","transformSortToTabular","replace","pluck","difference","v","isActive","allow_relatedList","getObjectFirstListView","first","getListViews","getListView","exac","listViews","getListViewIsRecent","listView","pickObjectMobileColumns","count","getField","isNameColumn","itemCount","maxCount","maxRows","nameColumn","nameKey","result","getObjectDefaultView","defaultView","use_mobile_columns","isAllView","isRecentView","tabularColumns","tabular_sort","column_index","transformSortToDX","dx_sort","RegEx","code","RegExp","_regExMessages","_globalMessages","regEx","exp","msg","messages","evalInContext","js","eval","call","convertField","getOption","option","foo","color","allOptions","picklist","picklistOptions","getPicklist","getPickListOptions","reverse","enable","defaultValue","triggers","trigger","_todo","_todo_from_code","_todo_from_db","on","todo","systemBaseFields","omit","required","readonly","getSystemBaseFields","_visible","error1","actionsByName","trim","isExpression","visible","record_permissions","globalData","assign","now","parseSingleExpression","_options","_type","beforeOpenFunction","is_company_limited","max","min","_option","k","_regEx","_min","_max","Number","Boolean","_optionsFunction","_reference_to","_createFunction","_beforeOpenFunction","_filtersFunction","_defaultValue","_is_company_limited","_filters","isDate","pop","_is_date","form","val","relatedObjInfo","PREFIX","_prependPrefixForFormula","prefix","fieldVariable","reg","rev","m","$1","formula_str","_CONTEXT","_VALUES","data","isBoolean","toastr","formatObjectName","_baseObject","_db","defaultListViewId","disabled_list_views","ref3","schema","self","baseObject","permission_set","icon","description","is_view","hasImportTemplates","version","is_enable","allow_customActions","exclude_actions","enable_search","paging","enable_api","custom","enable_share","enable_tree","sidebar","open_window","filter_company","calendar","enable_chatter","enable_trash","enable_space_global","enable_follow","enable_workflow","enable_inline_edit","details","masters","lookup_details","in_development","idFieldName","database_name","is_name","primary","filterable","item_name","copyItem","admin","all","list_view_item","ReactiveVar","createCollection","_name","getObjectSchema","contains","attachSchema","_simpleSchema","getObjectODataRouterPrefix","bootstrapLoaded","getSelectOptions","fieldSchema","data_type","optionItem","fieldsArr","_ref_obj","autoform_type","collectionName","fs","fsType","isUnLimited","multiple","rows","language","isMobile","isPad","isiOS","afFieldInput","timezoneId","dxDateBoxOptions","displayFormat","pickerType","dateMobileOptions","outFormat","showIcon","dependOn","depend_on","create","lookup_field","Modal","show","formId","operation","onSuccess","addItems","reference_sort","optionsSort","reference_limit","optionsLimit","reference_to_field","referenceToField","blackbox","objectSwitche","optionsMethod","optionsMethodParams","references","_reference","link","defaultIcon","firstOption","decimal","precision","scale","disabled","Array","editable","accept","system","Email","isNumber","optional","unique","group","searchable","inlineHelpText","isProduction","sortable","getFieldDisplayValue","field_value","html","moment","format","checkFieldTypeSupportBetweenQuery","field_type","includes","pushBetweenBuiltinOptionals","operations","builtinValues","getBetweenBuiltinValues","builtinItem","is_check_only","getBetweenTimeBuiltinValues","getBetweenBuiltinValueItem","getBetweenTimeBuiltinValueItem","getBetweenBuiltinOperation","betweenBuiltinValues","getQuarterStartMonth","month","getMonth","getLastQuarterFirstDay","year","getFullYear","getNextQuarterFirstDay","getMonthDays","days","endDate","millisecond","startDate","getLastMonthFirstDay","currentMonth","currentYear","endValue","firstDay","lastDay","lastMonday","lastMonthFinalDay","lastMonthFirstDay","lastQuarterEndDay","lastQuarterStartDay","lastSunday","last_120_days","last_30_days","last_60_days","last_7_days","last_90_days","minusDay","monday","nextMonday","nextMonthFinalDay","nextMonthFirstDay","nextQuarterEndDay","nextQuarterStartDay","nextSunday","nextYear","next_120_days","next_30_days","next_60_days","next_7_days","next_90_days","previousYear","startValue","strEndDay","strFirstDay","strLastDay","strMonday","strStartDay","strSunday","strToday","strTomorrow","strYestday","sunday","thisQuarterEndDay","thisQuarterStartDay","tomorrow","week","yestday","getDay","t","fv","setHours","getHours","getTimezoneOffset","getFieldDefaultOperation","getFieldOperation","optionals","equal","unequal","less_than","greater_than","less_or_equal","greater_or_equal","not_contain","starts_with","between","getObjectFieldsName","fieldsName","sort_no","cleanTrigger","initTrigger","_trigger_hooks","ref4","ref5","todoWrapper","apply","arguments","when","before","insert","update","remove","after","_hook","trigger_name","_trigger_hook","baseBooleanPermissionPropNames","extendPermissionProps","findOne_permission_object","find_permission_object","intersectionPlus","otherPermissionPropNames","overlayBaseBooleanPermissionProps","permissionPropNames","unionPermissionObjects","unionPlus","getObjectPermissions","getRecordPermissions","isOwner","masterObjectName","masterRecordPerm","record_company_id","record_company_ids","user_company_ids","owner","parent","n","intersection","locked","getRecordRelatedListPermissions","currentObjectName","relatedListItem","currentRecord","isRelateObjectUneditable","masterAllow","relatedObjectPermissions","uneditable_related_list","getObjectRecord","getRecordSafeRelatedList","getAllPermissions","_i","psets","psetsAdmin","psetsAdmin_pos","psetsCurrent","psetsCurrentNames","psetsCurrent_pos","psetsCustomer","psetsCustomer_pos","psetsGuest","psetsGuest_pos","psetsMember","psetsMember_pos","psetsSupplier","psetsSupplier_pos","psetsUser","psetsUser_pos","set_ids","spaceUser","objects","assigned_apps","profile","users","permission_set_id","modified","created_by","modified_by","getAssignedApps","bind","assigned_menus","getAssignedMenus","user_permission_sets","array","other","target","props","filesProNames","propNames","propName","apps","psetBase","userProfile","pset","uniq","aboutMenu","adminMenus","allMenus","currentPsetNames","menus","otherMenuApps","otherMenus","admin_menus","flatten","menu","psetsMenu","permission_sets","permission_objects","isNull","permission_set_ids","pos","ops","ops_key","currentPset","tempOps","repeatIndex","repeatPo","opsetAdmin","opsetCustomer","opsetGuest","opsetMember","opsetSupplier","opsetUser","posAdmin","posCustomer","posGuest","posMember","posSupplier","posUser","prof","guest","member","supplier","customer","disabled_actions","unreadable_fields","uneditable_fields","creator_db_url","oplog_url","MONGO_URL_CREATOR","MONGO_OPLOG_URL_CREATOR","_CREATOR_DATASOURCE","_driver","MongoInternals","RemoteCollectionDriver","oplogUrl","collection_key","newCollection","SMSQueue","_deleteRecord","action_name","executeAction","item_element","callback","moreArgs","todoArgs","ObjectGrid","getFilters","word_template","SteedosFilters","formatFiltersToODataQuery","absoluteUrl","window","open","odata","prototype","slice","concat","warning","record_title","call_back","call_back_error","previousDoc","FormManager","getPreviousDoc","info","success","runHook","relatedObjectStandardNew","collection_name","current_object_name","current_record_id","defaultDoc","initialValues","relateObject","set","getRelatedInitialValues","SteedosUI","showModal","stores","ComponentRegistry","components","ObjectForm","objectApiName","title","afterInsert","reloadRecord","FlowRouter","reload","iconPath","defer","$","click","gridName","isRelated","masterRecordId","relatedFieldName","selectedRows","gridRefs","current","api","getSelectedRows","gridRef","getInitialValues","Page","Form","StandardNew","render","href","getObjectUrl","redirect","StandardEdit","beforeHook","i18nTextKey","i18nTitleKey","nameField","selectedRecords","text","getTableSelectedRows","swal","showCancelButton","confirmButtonText","cancelButtonText","afterBatchesDelete","deleteCounter","_e","appid","dxDataGridInstance","gridContainer","gridObjectNameClass","isOpenerRemove","recordUrl","tempNavRemoved","opener","route","endsWith","refreshGrid","dxTreeList","dxDataGrid","refresh","removeTempNavItem","close","go","addClass","removeClass","recordTitle"],"mappings":"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","file":"/packages/steedos_objects.js","sourcesContent":["@db = {}\nif !Creator?\n\t@Creator = {}\nCreator.Objects = {}\nCreator.Collections = {}\nCreator.Menus = []\nCreator.Apps = {}\nCreator.Dashboards = {}\nCreator.Reports = {}\nCreator.subs = {}\nCreator.steedosSchema = {}","this.db = {};\n\nif (typeof Creator === \"undefined\" || Creator === null) {\n  this.Creator = {};\n}\n\nCreator.Objects = {};\n\nCreator.Collections = {};\n\nCreator.Menus = [];\n\nCreator.Apps = {};\n\nCreator.Dashboards = {};\n\nCreator.Reports = {};\n\nCreator.subs = {};\n\nCreator.steedosSchema = {};\n","try\n\tif process.env.CREATOR_NODE_ENV == 'development'\n\t\tsteedosCore = require('@steedos/core')\n\t\tobjectql = require('@steedos/objectql')\n\t\tmoleculer = require(\"moleculer\");\n\t\tpackageLoader = require('@steedos/service-meteor-package-loader');\n\t\tAPIService = require('@steedos/service-api');\n\t\tMetadataService = require('@steedos/service-metadata-server');\n\t\tpackageService = require(\"@steedos/service-package-registry\");\n\t\tpath = require('path')\n\n\t\tconfig = objectql.getSteedosConfig();\n\t\tsettings = {\n\t\t\tbuilt_in_plugins: [\n\t\t\t\t\"@steedos/standard-space\",\n\t\t\t\t\"@steedos/standard-object-database\",\n\t\t\t\t\"@steedos/standard-process-approval\",\n\t\t\t\t\"@steedos/standard-collaboration\",\n\t\t\t\t\"@steedos/standard-ui\",\n\t\t\t\t\"@steedos/standard-permission\",\n\t\t\t\t\"@steedos/webapp-public\",\n\t\t\t\t\"@steedos/service-cachers-manager\",\n\t\t\t\t\"@steedos/unpkg\",\n\t\t\t\t\"@steedos/workflow\",\n\t\t\t\t\"@steedos/accounts\",\n\t\t\t\t\"@steedos/plugin-company\",\n\t\t\t\t\"@steedos/metadata-api\",\n\t\t\t\t\"@steedos/data-import\",\n\t\t\t\t# \"@steedos/service-fields-indexs\",\n\t\t\t\t\"@steedos/service-accounts\",\n\t\t\t\t\"@steedos/service-charts\",\n\t\t\t\t# \"@steedos/service-pages\",\n\t\t\t\t\"@steedos/service-package-registry\",\n\t\t   \t\t\"@steedos/service-package-tool\",\n\t\t\t\t# \"@steedos/standard-process\",\n\t\t\t\t\"@steedos/webapp-accounts\",\n\t\t\t\t\"@steedos/service-workflow\",\n\t\t\t\t\"@steedos/service-plugin-amis\",\n\t\t\t\t\"@steedos/service-files\",\n\t\t\t\t\"@steedos/service-sentry\",\n\t\t\t\t\"@steedos/service-identity-jwt\"\n\t\t\t],\n\t\t\tplugins: config.plugins\n\t\t}\n\t\tMeteor.startup ->\n\t\t\ttry\n\t\t\t\tbroker = new moleculer.ServiceBroker({\n\t\t\t\t\tnamespace: \"steedos\",\n\t\t\t\t\tnodeID: \"steedos-creator\",\n\t\t\t\t\tmetadata: {},\n\t\t\t\t\ttransporter: process.env.TRANSPORTER,\n\t\t\t\t\tcacher: process.env.CACHER,\n\t\t\t\t\tlogLevel: \"warn\",\n\t\t\t\t\tserializer: \"JSON\",\n\t\t\t\t\trequestTimeout: 60 * 1000,\n\t\t\t\t\tmaxCallLevel: 100,\n\n\t\t\t\t\theartbeatInterval: 10,\n\t\t\t\t\theartbeatTimeout: 30,\n\n\t\t\t\t\tcontextParamsCloning: false,\n\n\t\t\t\t\ttracking: {\n\t\t\t\t\t\tenabled: false,\n\t\t\t\t\t\tshutdownTimeout: 5000,\n\t\t\t\t\t},\n\n\t\t\t\t\tdisableBalancer: false,\n\n\t\t\t\t\tregistry: {\n\t\t\t\t\t\tstrategy: \"RoundRobin\",\n\t\t\t\t\t\tpreferLocal: true\n\t\t\t\t\t},\n\n\t\t\t\t\tbulkhead: {\n\t\t\t\t\t\tenabled: false,\n\t\t\t\t\t\tconcurrency: 10,\n\t\t\t\t\t\tmaxQueueSize: 100,\n\t\t\t\t\t},\n\t\t\t\t\tvalidator: true,\n\t\t\t\t\terrorHandler: null,\n\t\t\t\t\ttracing: {\n\t\t\t\t\t\tenabled: false,\n\t\t\t\t\t\texporter: {\n\t\t\t\t\t\t\ttype: \"Console\",\n\t\t\t\t\t\t\toptions: {\n\t\t\t\t\t\t\t\tlogger: null,\n\t\t\t\t\t\t\t\tcolors: true,\n\t\t\t\t\t\t\t\twidth: 100,\n\t\t\t\t\t\t\t\tgaugeWidth: 40\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t\tskipProcessEventRegistration: true,\n\n\t\t\t\t\tcreated: (broker)-> \n\t\t\t\t\t\t# Clear all cache entries\n\t\t\t\t\t\tbroker.logger.warn('Clear all cache entries on startup.')\n\t\t\t\t\t\tbroker.cacher.clean();\n\t\t\t\t});\n\n\t\t\t\tobjectql.broker.init(broker);\n\n\t\t\t\tobjectqlService = broker.createService(require(\"@steedos/service-objectql\"));\n\t\t\t\t\n\t\t\t\tprojectService = broker.createService({\n\t\t\t\t\tname: \"project-server\",\n\t\t\t\t\tnamespace: \"steedos\",\n\t\t\t\t\tmixins: [packageService],\n\t\t\t\t});\n\n\n\t\t\t\tmetadataService = broker.createService({\n\t\t\t\t\tname: 'metadata-server',\n\t\t\t\t\tmixins: [MetadataService],\n\t\t\t\t\tsettings: {\n\t\t\t\t\t} \n\t\t\t\t});\n\n\t\t\t\tuiService = broker.createService(require(\"@steedos/service-ui\"));\n\n\t\t\t\tapiService = broker.createService({\n\t\t\t\t\tname: \"api\",\n\t\t\t\t\tmixins: [APIService],\n\t\t\t\t\tsettings: {\n\t\t\t\t\t\tport: null\n\t\t\t\t\t} \n\t\t\t\t});\n\n\t\t\t\tpageService = broker.createService({\n\t\t\t\t\tname: \"@steedos/service-pages\",\n\t\t\t\t\tmixins: [require('@steedos/service-pages')],\n\t\t\t\t\tsettings: {\n\t\t\t\t\t\tport: null\n\t\t\t\t\t} \n\t\t\t\t});\n\n\t\t\t\tsteedosService = broker.createService({\n\t\t\t\t\tname: \"steedos-server\",\n\t\t\t\t\tmixins: [],\n\t\t\t\t\tsettings: {\n\t\t\t\t\t\tport: null\n\t\t\t\t\t},\n\t\t\t\t\tstarted: ()->\n\t\t\t\t\t\tsetTimeout ->\n\t\t\t\t\t\t\tbroker.emit 'steedos-server.started'\n\t\t\t\t\t\t\treturn\n\t\t\t\t\t\t, 1000\n\t\t\t\t});\n\n\t\t\t\tobjectql.getSteedosSchema(broker);\n\t\t\t\tstandardObjectsDir = objectql.StandardObjectsPath;\n\t\t\t\tstandardObjectsPackageLoaderService = broker.createService({\n\t\t\t\t\tname: 'standard-objects',\n\t\t\t\t\tmixins: [packageLoader],\n\t\t\t\t\tsettings: { packageInfo: {\n\t\t\t\t\t\tpath: standardObjectsDir,\n\t\t\t\t\t} }\n\t\t\t\t});\n\n\t\t\t\tMeteor.wrapAsync((cb)->\n\t\t\t\t\tbroker.start().then(()->\n\t\t\t\t\t\tif !broker.started \n\t\t\t\t\t\t\tbroker._restartService(objectqlService);\n\t\t\t\t\t\t\tbroker._restartService(standardObjectsPackageLoaderService);\n\t\t\t\t\t\t\tbroker._restartService(uiService);\n\n\t\t\t\t\t\texpress = require('express');\n\t\t\t\t\t\tconnectHandlersExpress = express();\n\t\t\t\t\t\tconnectHandlersExpress.use(require('@steedos/router').staticRouter());\n\t\t\t\t\t\tbroker.waitForServices('~packages-@steedos/service-ui').then ()->\n\t\t\t\t\t\t\tconsole.log('waitForServices ~packages-@steedos/service-ui')\n\t\t\t\t\t\t\tconnectHandlersExpress.use(SteedosApi.express())\n\t\t\t\t\t\t\tWebApp.connectHandlers.use(connectHandlersExpress)\n\t\t\t\t\t\t\n\t\t\t\t\t\t# steedosCore.init(settings).then ()->\n\t\t\t\t\t\t# \tcb();\n\n\t\t\t\t\t\tbroker.waitForServices(standardObjectsPackageLoaderService.name).then (resolve, reject) ->\n\t\t\t\t\t\t\tsteedosCore.init(settings).then ()->\n\t\t\t\t\t\t\t\tcb(reject, resolve)\n\t\t\t\t\t)\n\t\t\t\t)()\n\t\t\tcatch ex\n\t\t\t\tconsole.error(\"error:\",ex)\ncatch e\n\tconsole.error(\"error:\",e)","var APIService, MetadataService, config, e, moleculer, objectql, packageLoader, packageService, path, settings, steedosCore;\n\ntry {\n  if (process.env.CREATOR_NODE_ENV === 'development') {\n    steedosCore = require('@steedos/core');\n    objectql = require('@steedos/objectql');\n    moleculer = require(\"moleculer\");\n    packageLoader = require('@steedos/service-meteor-package-loader');\n    APIService = require('@steedos/service-api');\n    MetadataService = require('@steedos/service-metadata-server');\n    packageService = require(\"@steedos/service-package-registry\");\n    path = require('path');\n    config = objectql.getSteedosConfig();\n    settings = {\n      built_in_plugins: [\"@steedos/standard-space\", \"@steedos/standard-object-database\", \"@steedos/standard-process-approval\", \"@steedos/standard-collaboration\", \"@steedos/standard-ui\", \"@steedos/standard-permission\", \"@steedos/webapp-public\", \"@steedos/service-cachers-manager\", \"@steedos/unpkg\", \"@steedos/workflow\", \"@steedos/accounts\", \"@steedos/plugin-company\", \"@steedos/metadata-api\", \"@steedos/data-import\", \"@steedos/service-accounts\", \"@steedos/service-charts\", \"@steedos/service-package-registry\", \"@steedos/service-package-tool\", \"@steedos/webapp-accounts\", \"@steedos/service-workflow\", \"@steedos/service-plugin-amis\", \"@steedos/service-files\", \"@steedos/service-sentry\", \"@steedos/service-identity-jwt\"],\n      plugins: config.plugins\n    };\n    Meteor.startup(function() {\n      var apiService, broker, ex, metadataService, objectqlService, pageService, projectService, standardObjectsDir, standardObjectsPackageLoaderService, steedosService, uiService;\n      try {\n        broker = new moleculer.ServiceBroker({\n          namespace: \"steedos\",\n          nodeID: \"steedos-creator\",\n          metadata: {},\n          transporter: process.env.TRANSPORTER,\n          cacher: process.env.CACHER,\n          logLevel: \"warn\",\n          serializer: \"JSON\",\n          requestTimeout: 60 * 1000,\n          maxCallLevel: 100,\n          heartbeatInterval: 10,\n          heartbeatTimeout: 30,\n          contextParamsCloning: false,\n          tracking: {\n            enabled: false,\n            shutdownTimeout: 5000\n          },\n          disableBalancer: false,\n          registry: {\n            strategy: \"RoundRobin\",\n            preferLocal: true\n          },\n          bulkhead: {\n            enabled: false,\n            concurrency: 10,\n            maxQueueSize: 100\n          },\n          validator: true,\n          errorHandler: null,\n          tracing: {\n            enabled: false,\n            exporter: {\n              type: \"Console\",\n              options: {\n                logger: null,\n                colors: true,\n                width: 100,\n                gaugeWidth: 40\n              }\n            }\n          },\n          skipProcessEventRegistration: true,\n          created: function(broker) {\n            broker.logger.warn('Clear all cache entries on startup.');\n            return broker.cacher.clean();\n          }\n        });\n        objectql.broker.init(broker);\n        objectqlService = broker.createService(require(\"@steedos/service-objectql\"));\n        projectService = broker.createService({\n          name: \"project-server\",\n          namespace: \"steedos\",\n          mixins: [packageService]\n        });\n        metadataService = broker.createService({\n          name: 'metadata-server',\n          mixins: [MetadataService],\n          settings: {}\n        });\n        uiService = broker.createService(require(\"@steedos/service-ui\"));\n        apiService = broker.createService({\n          name: \"api\",\n          mixins: [APIService],\n          settings: {\n            port: null\n          }\n        });\n        pageService = broker.createService({\n          name: \"@steedos/service-pages\",\n          mixins: [require('@steedos/service-pages')],\n          settings: {\n            port: null\n          }\n        });\n        steedosService = broker.createService({\n          name: \"steedos-server\",\n          mixins: [],\n          settings: {\n            port: null\n          },\n          started: function() {\n            return setTimeout(function() {\n              broker.emit('steedos-server.started');\n            }, 1000);\n          }\n        });\n        objectql.getSteedosSchema(broker);\n        standardObjectsDir = objectql.StandardObjectsPath;\n        standardObjectsPackageLoaderService = broker.createService({\n          name: 'standard-objects',\n          mixins: [packageLoader],\n          settings: {\n            packageInfo: {\n              path: standardObjectsDir\n            }\n          }\n        });\n        return Meteor.wrapAsync(function(cb) {\n          return broker.start().then(function() {\n            var connectHandlersExpress, express;\n            if (!broker.started) {\n              broker._restartService(objectqlService);\n              broker._restartService(standardObjectsPackageLoaderService);\n              broker._restartService(uiService);\n            }\n            express = require('express');\n            connectHandlersExpress = express();\n            connectHandlersExpress.use(require('@steedos/router').staticRouter());\n            broker.waitForServices('~packages-@steedos/service-ui').then(function() {\n              console.log('waitForServices ~packages-@steedos/service-ui');\n              connectHandlersExpress.use(SteedosApi.express());\n              return WebApp.connectHandlers.use(connectHandlersExpress);\n            });\n            return broker.waitForServices(standardObjectsPackageLoaderService.name).then(function(resolve, reject) {\n              return steedosCore.init(settings).then(function() {\n                return cb(reject, resolve);\n              });\n            });\n          });\n        })();\n      } catch (error) {\n        ex = error;\n        return console.error(\"error:\", ex);\n      }\n    });\n  }\n} catch (error) {\n  e = error;\n  console.error(\"error:\", e);\n}\n","Creator.deps = {\n\tapp: new Tracker.Dependency\n\tobject: new Tracker.Dependency\n};\n\nCreator._TEMPLATE = {\n\tApps: {},\n\tObjects: {}\n}\n\nMeteor.startup ->\n\tSimpleSchema.extendOptions({filtersFunction: Match.Optional(Match.OneOf(Function, String))})\n\tSimpleSchema.extendOptions({optionsFunction: Match.Optional(Match.OneOf(Function, String))})\n\tSimpleSchema.extendOptions({createFunction: Match.Optional(Match.OneOf(Function, String))})\n\n# Creator.fiberLoadObjects 供steedos-cli项目使用\nif Meteor.isServer\n\tFiber = require('fibers')\n\tCreator.fiberLoadObjects = (obj, object_name)->\n\t\tFiber(()->\n\t\t\tCreator.loadObjects(obj, object_name)\n\t\t).run()\n\nCreator.loadObjects = (obj, object_name)->\n\tif !object_name\n\t\tobject_name = obj.name\n\n\tif !obj.list_views\n\t\tobj.list_views = {}\n\n\tif obj.space\n\t\tobject_name = Creator.getCollectionName(obj)\n\tif object_name == 'cfs_files_filerecord'\n\t\tobject_name = 'cfs.files.filerecord'\n\t\tobj = _.clone(obj)\n\t\tobj.name = object_name\n\t\tCreator.Objects[object_name] = obj\n\n\tCreator.convertObject(obj)\n\tnew Creator.Object(obj);\n\n\tCreator.initTriggers(object_name)\n\tCreator.initListViews(object_name)\n\treturn obj\n\nCreator.getObjectName = (object) ->\n\tif object.space\n\t\treturn \"c_#{object.space}_#{object.name}\"\n\treturn object.name\n\nCreator.getObject = (object_name, space_id)->\n\tif _.isArray(object_name)\n\t\treturn ;\n\tif Meteor.isClient\n\t\tCreator.deps?.object?.depend()\n\tif !object_name and Meteor.isClient\n\t\tobject_name = Session.get(\"object_name\")\n\n#\tif !space_id && object_name\n#\t\tif Meteor.isClient && !object_name.startsWith('c_')\n#\t\t\tspace_id = Session.get(\"spaceId\")\n\n\tif object_name\n#\t\tif space_id\n#\t\t\tobj = Creator.objectsByName[\"c_#{space_id}_#{object_name}\"]\n#\t\t\tif obj\n#\t\t\t\treturn obj\n#\n#\t\tobj = _.find Creator.objectsByName, (o)->\n#\t\t\t\treturn o._collection_name == object_name\n#\t\tif obj\n#\t\t\treturn obj\n\n\t\treturn Creator.objectsByName[object_name]\n\nCreator.getObjectById = (object_id)->\n\treturn _.findWhere(Creator.objectsByName, {_id: object_id})\n\nCreator.removeObject = (object_name)->\n\tconsole.log(\"removeObject\", object_name)\n\tdelete Creator.Objects[object_name]\n\tdelete Creator.objectsByName[object_name]\n\nCreator.getCollection = (object_name, spaceId)->\n\tif !object_name\n\t\tobject_name = Session.get(\"object_name\")\n\tif object_name\n\t\tif Meteor.isClient\n\t\t\treturn db[object_name]\n\t\telse\n\t\t\treturn Creator.Collections[Creator.getObject(object_name, spaceId)?._collection_name || object_name]\n\nCreator.removeCollection = (object_name)->\n\tdelete Creator.Collections[object_name]\n\nCreator.isSpaceAdmin = (spaceId, userId)->\n\tif Meteor.isClient\n\t\tif !spaceId\n\t\t\tspaceId = Session.get(\"spaceId\")\n\t\tif !userId\n\t\t\tuserId = Meteor.userId()\n\n\tspace = Creator.getObject(\"spaces\")?.db?.findOne(spaceId,{fields:{admins:1}})\n\tif space?.admins\n\t\treturn space.admins.indexOf(userId) >= 0\n\n\nCreator.evaluateFormula = (formular, context, options)->\n\n\tif !_.isString(formular)\n\t\treturn formular\n\n\tif Creator.Formular.checkFormula(formular)\n\t\treturn Creator.Formular.run(formular, context, options)\n\n\treturn formular\n\nCreator.evaluateFilters = (filters, context)->\n\tselector = {}\n\t_.each filters, (filter)->\n\t\tif filter?.length == 3\n\t\t\tname = filter[0]\n\t\t\taction = filter[1]\n\t\t\tvalue = Creator.evaluateFormula(filter[2], context)\n\t\t\tselector[name] = {}\n\t\t\tselector[name][action] = value\n\t# console.log(\"evaluateFilters-->selector\", selector)\n\treturn selector\n\nCreator.isCommonSpace = (spaceId) ->\n\treturn spaceId == 'common'\n\n###\n\tdocs：待排序的文档数组\n\tids：_id集合\n\tid_key: 默认为_id\n\treturn 按照ids的顺序返回新的文档集合\n###\nCreator.getOrderlySetByIds = (docs, ids, id_key, hit_first)->\n\n\tif !id_key\n\t\tid_key = \"_id\"\n\n\tif hit_first\n\n\t\t#由于不能使用_.findIndex函数，因此此处先将对象数组转为普通数组类型，在获取其index\n\t\tvalues = docs.getProperty(id_key)\n\n\t\treturn\t_.sortBy docs, (doc)->\n\t\t\t\t\t_index = ids.indexOf(doc[id_key])\n\t\t\t\t\tif _index > -1\n\t\t\t\t\t\treturn _index\n\t\t\t\t\telse\n\t\t\t\t\t\treturn ids.length + _.indexOf(values, doc[id_key])\n\telse\n\t\treturn\t_.sortBy docs, (doc)->\n\t\t\treturn ids.indexOf(doc[id_key])\n\n###\n\t按用户所属本地化语言进行排序，支持中文、数值、日期等字段排序\n\t对于Object类型，如果提供作用域中key属性，则取值为value[key]进行排序比较，反之整个Object.toString()后排序比较\n###\nCreator.sortingMethod = (value1, value2) ->\n\tif this.key\n\t\tvalue1 = value1[this.key]\n\t\tvalue2 = value2[this.key]\n\tif value1 instanceof Date\n\t\tvalue1 = value1.getTime()\n\tif value2 instanceof Date\n\t\tvalue2 = value2.getTime()\n\tif typeof value1 is \"number\" and typeof value2 is \"number\"\n\t\treturn value1 - value2\n\t# Handling null values\n\tisValue1Empty = value1 == null or value1 == undefined\n\tisValue2Empty = value2 == null or value2 == undefined\n\tif isValue1Empty and !isValue2Empty\n\t\treturn -1\n\tif isValue1Empty and isValue2Empty\n\t\treturn 0\n\tif !isValue1Empty and isValue2Empty\n\t\treturn 1\n\tlocale = Steedos.locale()\n\treturn value1.toString().localeCompare value2.toString(), locale\n\n\n# 该函数只在初始化Object时，把相关对象的计算结果保存到Object的related_objects属性中，后续可以直接从related_objects属性中取得计算结果而不用再次调用该函数来计算\nCreator.getObjectRelateds = (object_name)->\n\tif Meteor.isClient\n\t\tif !object_name\n\t\t\tobject_name = Session.get(\"object_name\")\n\n\trelated_objects = []\n\t# _object = Creator.getObject(object_name)\n\t# 因Creator.getObject函数内部要调用该函数，所以这里不可以调用Creator.getObject取对象，只能调用Creator.Objects来取对象\n\t_object = Creator.Objects[object_name]\n\tif !_object\n\t\treturn related_objects\n\t\n\trelatedList = _object.relatedList\n\tif Meteor.isClient && !_.isEmpty relatedList\n\t\trelatedListMap = {}\n\t\t_.each relatedList, (objName)->\n\t\t\tif _.isObject objName\n\t\t\t\trelatedListMap[objName.objectName] = {}\n\t\t\telse\n\t\t\t\trelatedListMap[objName] = {}\n\t\t_.each Creator.Objects, (related_object, related_object_name)->\n\t\t\t_.each related_object.fields, (related_field, related_field_name)->\n\t\t\t\tif (related_field.type == \"master_detail\" || related_field.type == \"lookup\") and related_field.reference_to and related_field.reference_to == object_name and relatedListMap[related_object_name]\n\t\t\t\t\t# 当related_object.fields中有两个或以上的字段指向object_name表示的对象时，优先取第一个作为外键关系字段，但是related_field为主子表时强行覆盖之前的relatedListMap[related_object_name]值\n\t\t\t\t\tif _.isEmpty relatedListMap[related_object_name] || related_field.type == \"master_detail\"\n\t\t\t\t\t\trelatedListMap[related_object_name] = { object_name: related_object_name, foreign_key: related_field_name, write_requires_master_read: related_field.write_requires_master_read }\n\t\tif relatedListMap['cms_files']\n\t\t\trelatedListMap['cms_files'] = { object_name: \"cms_files\", foreign_key: \"parent\" }\n\t\tif relatedListMap['instances']\n\t\t\trelatedListMap['instances'] = { object_name: \"instances\", foreign_key: \"record_ids\" }\n\t\t_.each ['tasks', 'notes', 'events', 'approvals'], (enableObjName)->\n\t\t\tif relatedListMap[enableObjName]\n\t\t\t\trelatedListMap[enableObjName] = { object_name: enableObjName, foreign_key: \"related_to\" }\n\t\tif relatedListMap['audit_records']\n\t\t\t#record 详细下的audit_records仅modifyAllRecords权限可见\n\t\t\tpermissions = Creator.getPermissions(object_name)\n\t\t\tif _object.enable_audit && permissions?.modifyAllRecords\n\t\t\t\trelatedListMap['audit_records'] = { object_name:\"audit_records\", foreign_key: \"related_to\" }\n\t\trelated_objects = _.values relatedListMap\n\t\treturn related_objects\n\n\tif _object.enable_files\n\t\trelated_objects.push {object_name:\"cms_files\", foreign_key: \"parent\"}\n\n\t_.each Creator.Objects, (related_object, related_object_name)->\n\t\tif related_object_name == \"cfs.files.filerecord\"\n\t\t\t# cfs.files.filerecord对象在第二次点击的时候related_object返回的是app-builder中的\"metadata.parent\"字段被删除了，记到metadata字段的sub_fields中了，所以要单独处理。\n\t\t\tsfsFilesObject = Creator.getObject(\"cfs.files.filerecord\")\n\t\t\tsfsFilesObject && related_object = sfsFilesObject\n\t\t_.each related_object.fields, (related_field, related_field_name)->\n\t\t\tif (related_field.type == \"master_detail\" || (related_field.type == \"lookup\" && related_field.relatedList)) and related_field.reference_to and related_field.reference_to == object_name\n\t\t\t\tif related_object_name == \"object_fields\"\n\t\t\t\t\t#TODO 待相关列表支持排序后，删除此判断\n\t\t\t\t\trelated_objects.splice(0, 0, {object_name:related_object_name, foreign_key: related_field_name})\n\t\t\t\telse\n\t\t\t\t\trelated_objects.push {object_name:related_object_name, foreign_key: related_field_name, write_requires_master_read: related_field.write_requires_master_read}\n\n\tif _object.enable_tasks\n\t\trelated_objects.push {object_name:\"tasks\", foreign_key: \"related_to\"}\n\tif _object.enable_notes\n\t\trelated_objects.push {object_name:\"notes\", foreign_key: \"related_to\"}\n\tif _object.enable_events\n\t\trelated_objects.push {object_name:\"events\", foreign_key: \"related_to\"}\n\tif _object.enable_instances\n\t\trelated_objects.push {object_name:\"instances\", foreign_key: \"record_ids\"}\n\tif _object.enable_approvals\n\t\trelated_objects.push {object_name:\"approvals\", foreign_key: \"related_to\"}\n\tif _object.enable_process\n\t\trelated_objects.push {object_name:\"process_instance_history\", foreign_key: \"target_object\"}\n\t#record 详细下的audit_records仅modifyAllRecords权限可见\n\tif Meteor.isClient\n\t\tpermissions = Creator.getPermissions(object_name)\n\t\tif _object.enable_audit && permissions?.modifyAllRecords\n\t\t\trelated_objects.push {object_name:\"audit_records\", foreign_key: \"related_to\"}\n\n\treturn related_objects\n\nCreator.getUserContext = (userId, spaceId, isUnSafeMode)->\n\tif Meteor.isClient\n\t\treturn Creator.USER_CONTEXT\n\telse\n\t\tif !(userId and spaceId)\n\t\t\tthrow new Meteor.Error 500, \"the params userId and spaceId is required for the function Creator.getUserContext\"\n\t\t\treturn null\n\t\tsuFields = {name: 1, mobile: 1, position: 1, email: 1, company: 1, organization: 1, space: 1, company_id: 1, company_ids: 1}\n\t\t# check if user in the space\n\t\tsu = Creator.Collections[\"space_users\"].findOne({space: spaceId, user: userId}, {fields: suFields})\n\t\tif !su\n\t\t\tspaceId = null\n\n\t\t# if spaceId not exists, get the first one.\n\t\tif !spaceId\n\t\t\tif isUnSafeMode\n\t\t\t\tsu = Creator.Collections[\"space_users\"].findOne({user: userId}, {fields: suFields})\n\t\t\t\tif !su\n\t\t\t\t\treturn null\n\t\t\t\tspaceId = su.space\n\t\t\telse\n\t\t\t\treturn null\n\n\t\tUSER_CONTEXT = {}\n\t\tUSER_CONTEXT.userId = userId\n\t\tUSER_CONTEXT.spaceId = spaceId\n\t\tUSER_CONTEXT.user = {\n\t\t\t_id: userId\n\t\t\tname: su.name,\n\t\t\tmobile: su.mobile,\n\t\t\tposition: su.position,\n\t\t\temail: su.email\n\t\t\tcompany: su.company\n\t\t\tcompany_id: su.company_id\n\t\t\tcompany_ids: su.company_ids\n\t\t}\n\t\tspace_user_org = Creator.getCollection(\"organizations\")?.findOne(su.organization)\n\t\tif space_user_org\n\t\t\tUSER_CONTEXT.user.organization = {\n\t\t\t\t_id: space_user_org._id,\n\t\t\t\tname: space_user_org.name,\n\t\t\t\tfullname: space_user_org.fullname\n\t\t\t}\n\t\treturn USER_CONTEXT\n\nCreator.getRelativeUrl = (url)->\n\n\tif _.isFunction(Steedos.isCordova) && Steedos.isCordova() && (url?.startsWith(\"/assets\") || url?.startsWith(\"assets\") || url?.startsWith(\"/packages\"))\n\t\tif !/^\\//.test(url)\n\t\t\turl = \"/\" + url\n\t\treturn url\n\n\tif url\n\t\t# url开头没有\"/\"，需要添加\"/\"\n\t\tif !/^\\//.test(url)\n\t\t\turl = \"/\" + url\n\t\treturn __meteor_runtime_config__.ROOT_URL_PATH_PREFIX + url\n\telse\n\t\treturn __meteor_runtime_config__.ROOT_URL_PATH_PREFIX\n\nCreator.getUserCompanyId = (userId, spaceId)->\n\tuserId = userId || Meteor.userId()\n\tif Meteor.isClient\n\t\tspaceId = spaceId || Session.get('spaceId')\n\telse\n\t\tif !spaceId\n\t\t\tthrow new Meteor.Error(400, 'miss spaceId')\n\tsu = Creator.getCollection('space_users').findOne({space: spaceId, user: userId}, {fields: {company_id:1}})\n\treturn su.company_id\n\nCreator.getUserCompanyIds = (userId, spaceId)->\n\tuserId = userId || Meteor.userId()\n\tif Meteor.isClient\n\t\tspaceId = spaceId || Session.get('spaceId')\n\telse\n\t\tif !spaceId\n\t\t\tthrow new Meteor.Error(400, 'miss spaceId')\n\tsu = Creator.getCollection('space_users').findOne({space: spaceId, user: userId}, {fields: {company_ids:1}})\n\treturn su?.company_ids\n\nCreator.processPermissions = (po)->\n\tif po.allowCreate\n\t\tpo.allowRead = true\n\tif po.allowEdit\n\t\tpo.allowRead = true\n\tif po.allowDelete\n\t\tpo.allowEdit = true\n\t\tpo.allowRead = true\n\tif po.viewAllRecords\n\t\tpo.allowRead = true\n\tif po.modifyAllRecords\n\t\tpo.allowRead = true\n\t\tpo.allowEdit = true\n\t\tpo.allowDelete = true\n\t\tpo.viewAllRecords = true\n\tif po.viewCompanyRecords\n\t\tpo.allowRead = true\n\tif po.modifyCompanyRecords\n\t\tpo.allowRead = true\n\t\tpo.allowEdit = true\n\t\tpo.allowDelete = true\n\t\tpo.viewCompanyRecords = true\n\t\t\n\t# 如果附件相关权限配置为空，则兼容之前没有附件权限配置时的规则\n\tif po.allowRead\n\t\ttypeof po.allowReadFiles != \"boolean\" && po.allowReadFiles = true\n\t\ttypeof po.viewAllFiles != \"boolean\" && po.viewAllFiles = true\n\tif po.allowEdit\n\t\ttypeof po.allowCreateFiles != \"boolean\" && po.allowCreateFiles = true\n\t\ttypeof po.allowEditFiles != \"boolean\" && po.allowEditFiles = true\n\t\ttypeof po.allowDeleteFiles != \"boolean\" && po.allowDeleteFiles = true\n\tif po.modifyAllRecords\n\t\ttypeof po.modifyAllFiles != \"boolean\" && po.modifyAllFiles = true\n\n\tif po.allowCreateFiles\n\t\tpo.allowReadFiles = true\n\tif po.allowEditFiles\n\t\tpo.allowReadFiles = true\n\tif po.allowDeleteFiles\n\t\tpo.allowEditFiles = true\n\t\tpo.allowReadFiles = true\n\tif po.viewAllFiles\n\t\tpo.allowReadFiles = true\n\tif po.modifyAllFiles\n\t\tpo.allowReadFiles = true\n\t\tpo.allowEditFiles = true\n\t\tpo.allowDeleteFiles = true\n\t\tpo.viewAllFiles = true\n\n\treturn po\n\nCreator.getTemplateSpaceId = ()->\n\treturn Meteor.settings.public?.templateSpaceId\n\nCreator.getCloudAdminSpaceId = ()->\n\treturn Meteor.settings.public?.cloudAdminSpaceId\n\nCreator.isTemplateSpace = (spaceId)->\n\tif spaceId && Meteor.settings.public?.templateSpaceId == spaceId\n\t\treturn true\n\treturn false\n\nCreator.isCloudAdminSpace = (spaceId)->\n\tif spaceId && Meteor.settings.public?.cloudAdminSpaceId == spaceId\n\t\treturn true\n\treturn false\n\nif Meteor.isServer\n\tCreator.steedosStorageDir = process.env.STEEDOS_STORAGE_DIR\n\t","var Fiber;\n\nCreator.deps = {\n  app: new Tracker.Dependency,\n  object: new Tracker.Dependency\n};\n\nCreator._TEMPLATE = {\n  Apps: {},\n  Objects: {}\n};\n\nMeteor.startup(function() {\n  SimpleSchema.extendOptions({\n    filtersFunction: Match.Optional(Match.OneOf(Function, String))\n  });\n  SimpleSchema.extendOptions({\n    optionsFunction: Match.Optional(Match.OneOf(Function, String))\n  });\n  return SimpleSchema.extendOptions({\n    createFunction: Match.Optional(Match.OneOf(Function, String))\n  });\n});\n\nif (Meteor.isServer) {\n  Fiber = require('fibers');\n  Creator.fiberLoadObjects = function(obj, object_name) {\n    return Fiber(function() {\n      return Creator.loadObjects(obj, object_name);\n    }).run();\n  };\n}\n\nCreator.loadObjects = function(obj, object_name) {\n  if (!object_name) {\n    object_name = obj.name;\n  }\n  if (!obj.list_views) {\n    obj.list_views = {};\n  }\n  if (obj.space) {\n    object_name = Creator.getCollectionName(obj);\n  }\n  if (object_name === 'cfs_files_filerecord') {\n    object_name = 'cfs.files.filerecord';\n    obj = _.clone(obj);\n    obj.name = object_name;\n    Creator.Objects[object_name] = obj;\n  }\n  Creator.convertObject(obj);\n  new Creator.Object(obj);\n  Creator.initTriggers(object_name);\n  Creator.initListViews(object_name);\n  return obj;\n};\n\nCreator.getObjectName = function(object) {\n  if (object.space) {\n    return \"c_\" + object.space + \"_\" + object.name;\n  }\n  return object.name;\n};\n\nCreator.getObject = function(object_name, space_id) {\n  var ref, ref1;\n  if (_.isArray(object_name)) {\n    return;\n  }\n  if (Meteor.isClient) {\n    if ((ref = Creator.deps) != null) {\n      if ((ref1 = ref.object) != null) {\n        ref1.depend();\n      }\n    }\n  }\n  if (!object_name && Meteor.isClient) {\n    object_name = Session.get(\"object_name\");\n  }\n  if (object_name) {\n    return Creator.objectsByName[object_name];\n  }\n};\n\nCreator.getObjectById = function(object_id) {\n  return _.findWhere(Creator.objectsByName, {\n    _id: object_id\n  });\n};\n\nCreator.removeObject = function(object_name) {\n  console.log(\"removeObject\", object_name);\n  delete Creator.Objects[object_name];\n  return delete Creator.objectsByName[object_name];\n};\n\nCreator.getCollection = function(object_name, spaceId) {\n  var ref;\n  if (!object_name) {\n    object_name = Session.get(\"object_name\");\n  }\n  if (object_name) {\n    if (Meteor.isClient) {\n      return db[object_name];\n    } else {\n      return Creator.Collections[((ref = Creator.getObject(object_name, spaceId)) != null ? ref._collection_name : void 0) || object_name];\n    }\n  }\n};\n\nCreator.removeCollection = function(object_name) {\n  return delete Creator.Collections[object_name];\n};\n\nCreator.isSpaceAdmin = function(spaceId, userId) {\n  var ref, ref1, space;\n  if (Meteor.isClient) {\n    if (!spaceId) {\n      spaceId = Session.get(\"spaceId\");\n    }\n    if (!userId) {\n      userId = Meteor.userId();\n    }\n  }\n  space = (ref = Creator.getObject(\"spaces\")) != null ? (ref1 = ref.db) != null ? ref1.findOne(spaceId, {\n    fields: {\n      admins: 1\n    }\n  }) : void 0 : void 0;\n  if (space != null ? space.admins : void 0) {\n    return space.admins.indexOf(userId) >= 0;\n  }\n};\n\nCreator.evaluateFormula = function(formular, context, options) {\n  if (!_.isString(formular)) {\n    return formular;\n  }\n  if (Creator.Formular.checkFormula(formular)) {\n    return Creator.Formular.run(formular, context, options);\n  }\n  return formular;\n};\n\nCreator.evaluateFilters = function(filters, context) {\n  var selector;\n  selector = {};\n  _.each(filters, function(filter) {\n    var action, name, value;\n    if ((filter != null ? filter.length : void 0) === 3) {\n      name = filter[0];\n      action = filter[1];\n      value = Creator.evaluateFormula(filter[2], context);\n      selector[name] = {};\n      return selector[name][action] = value;\n    }\n  });\n  return selector;\n};\n\nCreator.isCommonSpace = function(spaceId) {\n  return spaceId === 'common';\n};\n\n\n/*\n\tdocs：待排序的文档数组\n\tids：_id集合\n\tid_key: 默认为_id\n\treturn 按照ids的顺序返回新的文档集合\n */\n\nCreator.getOrderlySetByIds = function(docs, ids, id_key, hit_first) {\n  var values;\n  if (!id_key) {\n    id_key = \"_id\";\n  }\n  if (hit_first) {\n    values = docs.getProperty(id_key);\n    return _.sortBy(docs, function(doc) {\n      var _index;\n      _index = ids.indexOf(doc[id_key]);\n      if (_index > -1) {\n        return _index;\n      } else {\n        return ids.length + _.indexOf(values, doc[id_key]);\n      }\n    });\n  } else {\n    return _.sortBy(docs, function(doc) {\n      return ids.indexOf(doc[id_key]);\n    });\n  }\n};\n\n\n/*\n\t按用户所属本地化语言进行排序，支持中文、数值、日期等字段排序\n\t对于Object类型，如果提供作用域中key属性，则取值为value[key]进行排序比较，反之整个Object.toString()后排序比较\n */\n\nCreator.sortingMethod = function(value1, value2) {\n  var isValue1Empty, isValue2Empty, locale;\n  if (this.key) {\n    value1 = value1[this.key];\n    value2 = value2[this.key];\n  }\n  if (value1 instanceof Date) {\n    value1 = value1.getTime();\n  }\n  if (value2 instanceof Date) {\n    value2 = value2.getTime();\n  }\n  if (typeof value1 === \"number\" && typeof value2 === \"number\") {\n    return value1 - value2;\n  }\n  isValue1Empty = value1 === null || value1 === void 0;\n  isValue2Empty = value2 === null || value2 === void 0;\n  if (isValue1Empty && !isValue2Empty) {\n    return -1;\n  }\n  if (isValue1Empty && isValue2Empty) {\n    return 0;\n  }\n  if (!isValue1Empty && isValue2Empty) {\n    return 1;\n  }\n  locale = Steedos.locale();\n  return value1.toString().localeCompare(value2.toString(), locale);\n};\n\nCreator.getObjectRelateds = function(object_name) {\n  var _object, permissions, relatedList, relatedListMap, related_objects;\n  if (Meteor.isClient) {\n    if (!object_name) {\n      object_name = Session.get(\"object_name\");\n    }\n  }\n  related_objects = [];\n  _object = Creator.Objects[object_name];\n  if (!_object) {\n    return related_objects;\n  }\n  relatedList = _object.relatedList;\n  if (Meteor.isClient && !_.isEmpty(relatedList)) {\n    relatedListMap = {};\n    _.each(relatedList, function(objName) {\n      if (_.isObject(objName)) {\n        return relatedListMap[objName.objectName] = {};\n      } else {\n        return relatedListMap[objName] = {};\n      }\n    });\n    _.each(Creator.Objects, function(related_object, related_object_name) {\n      return _.each(related_object.fields, function(related_field, related_field_name) {\n        if ((related_field.type === \"master_detail\" || related_field.type === \"lookup\") && related_field.reference_to && related_field.reference_to === object_name && relatedListMap[related_object_name]) {\n          if (_.isEmpty(relatedListMap[related_object_name] || related_field.type === \"master_detail\")) {\n            return relatedListMap[related_object_name] = {\n              object_name: related_object_name,\n              foreign_key: related_field_name,\n              write_requires_master_read: related_field.write_requires_master_read\n            };\n          }\n        }\n      });\n    });\n    if (relatedListMap['cms_files']) {\n      relatedListMap['cms_files'] = {\n        object_name: \"cms_files\",\n        foreign_key: \"parent\"\n      };\n    }\n    if (relatedListMap['instances']) {\n      relatedListMap['instances'] = {\n        object_name: \"instances\",\n        foreign_key: \"record_ids\"\n      };\n    }\n    _.each(['tasks', 'notes', 'events', 'approvals'], function(enableObjName) {\n      if (relatedListMap[enableObjName]) {\n        return relatedListMap[enableObjName] = {\n          object_name: enableObjName,\n          foreign_key: \"related_to\"\n        };\n      }\n    });\n    if (relatedListMap['audit_records']) {\n      permissions = Creator.getPermissions(object_name);\n      if (_object.enable_audit && (permissions != null ? permissions.modifyAllRecords : void 0)) {\n        relatedListMap['audit_records'] = {\n          object_name: \"audit_records\",\n          foreign_key: \"related_to\"\n        };\n      }\n    }\n    related_objects = _.values(relatedListMap);\n    return related_objects;\n  }\n  if (_object.enable_files) {\n    related_objects.push({\n      object_name: \"cms_files\",\n      foreign_key: \"parent\"\n    });\n  }\n  _.each(Creator.Objects, function(related_object, related_object_name) {\n    var sfsFilesObject;\n    if (related_object_name === \"cfs.files.filerecord\") {\n      sfsFilesObject = Creator.getObject(\"cfs.files.filerecord\");\n      sfsFilesObject && (related_object = sfsFilesObject);\n    }\n    return _.each(related_object.fields, function(related_field, related_field_name) {\n      if ((related_field.type === \"master_detail\" || (related_field.type === \"lookup\" && related_field.relatedList)) && related_field.reference_to && related_field.reference_to === object_name) {\n        if (related_object_name === \"object_fields\") {\n          return related_objects.splice(0, 0, {\n            object_name: related_object_name,\n            foreign_key: related_field_name\n          });\n        } else {\n          return related_objects.push({\n            object_name: related_object_name,\n            foreign_key: related_field_name,\n            write_requires_master_read: related_field.write_requires_master_read\n          });\n        }\n      }\n    });\n  });\n  if (_object.enable_tasks) {\n    related_objects.push({\n      object_name: \"tasks\",\n      foreign_key: \"related_to\"\n    });\n  }\n  if (_object.enable_notes) {\n    related_objects.push({\n      object_name: \"notes\",\n      foreign_key: \"related_to\"\n    });\n  }\n  if (_object.enable_events) {\n    related_objects.push({\n      object_name: \"events\",\n      foreign_key: \"related_to\"\n    });\n  }\n  if (_object.enable_instances) {\n    related_objects.push({\n      object_name: \"instances\",\n      foreign_key: \"record_ids\"\n    });\n  }\n  if (_object.enable_approvals) {\n    related_objects.push({\n      object_name: \"approvals\",\n      foreign_key: \"related_to\"\n    });\n  }\n  if (_object.enable_process) {\n    related_objects.push({\n      object_name: \"process_instance_history\",\n      foreign_key: \"target_object\"\n    });\n  }\n  if (Meteor.isClient) {\n    permissions = Creator.getPermissions(object_name);\n    if (_object.enable_audit && (permissions != null ? permissions.modifyAllRecords : void 0)) {\n      related_objects.push({\n        object_name: \"audit_records\",\n        foreign_key: \"related_to\"\n      });\n    }\n  }\n  return related_objects;\n};\n\nCreator.getUserContext = function(userId, spaceId, isUnSafeMode) {\n  var USER_CONTEXT, ref, space_user_org, su, suFields;\n  if (Meteor.isClient) {\n    return Creator.USER_CONTEXT;\n  } else {\n    if (!(userId && spaceId)) {\n      throw new Meteor.Error(500, \"the params userId and spaceId is required for the function Creator.getUserContext\");\n      return null;\n    }\n    suFields = {\n      name: 1,\n      mobile: 1,\n      position: 1,\n      email: 1,\n      company: 1,\n      organization: 1,\n      space: 1,\n      company_id: 1,\n      company_ids: 1\n    };\n    su = Creator.Collections[\"space_users\"].findOne({\n      space: spaceId,\n      user: userId\n    }, {\n      fields: suFields\n    });\n    if (!su) {\n      spaceId = null;\n    }\n    if (!spaceId) {\n      if (isUnSafeMode) {\n        su = Creator.Collections[\"space_users\"].findOne({\n          user: userId\n        }, {\n          fields: suFields\n        });\n        if (!su) {\n          return null;\n        }\n        spaceId = su.space;\n      } else {\n        return null;\n      }\n    }\n    USER_CONTEXT = {};\n    USER_CONTEXT.userId = userId;\n    USER_CONTEXT.spaceId = spaceId;\n    USER_CONTEXT.user = {\n      _id: userId,\n      name: su.name,\n      mobile: su.mobile,\n      position: su.position,\n      email: su.email,\n      company: su.company,\n      company_id: su.company_id,\n      company_ids: su.company_ids\n    };\n    space_user_org = (ref = Creator.getCollection(\"organizations\")) != null ? ref.findOne(su.organization) : void 0;\n    if (space_user_org) {\n      USER_CONTEXT.user.organization = {\n        _id: space_user_org._id,\n        name: space_user_org.name,\n        fullname: space_user_org.fullname\n      };\n    }\n    return USER_CONTEXT;\n  }\n};\n\nCreator.getRelativeUrl = function(url) {\n  if (_.isFunction(Steedos.isCordova) && Steedos.isCordova() && ((url != null ? url.startsWith(\"/assets\") : void 0) || (url != null ? url.startsWith(\"assets\") : void 0) || (url != null ? url.startsWith(\"/packages\") : void 0))) {\n    if (!/^\\//.test(url)) {\n      url = \"/\" + url;\n    }\n    return url;\n  }\n  if (url) {\n    if (!/^\\//.test(url)) {\n      url = \"/\" + url;\n    }\n    return __meteor_runtime_config__.ROOT_URL_PATH_PREFIX + url;\n  } else {\n    return __meteor_runtime_config__.ROOT_URL_PATH_PREFIX;\n  }\n};\n\nCreator.getUserCompanyId = function(userId, spaceId) {\n  var su;\n  userId = userId || Meteor.userId();\n  if (Meteor.isClient) {\n    spaceId = spaceId || Session.get('spaceId');\n  } else {\n    if (!spaceId) {\n      throw new Meteor.Error(400, 'miss spaceId');\n    }\n  }\n  su = Creator.getCollection('space_users').findOne({\n    space: spaceId,\n    user: userId\n  }, {\n    fields: {\n      company_id: 1\n    }\n  });\n  return su.company_id;\n};\n\nCreator.getUserCompanyIds = function(userId, spaceId) {\n  var su;\n  userId = userId || Meteor.userId();\n  if (Meteor.isClient) {\n    spaceId = spaceId || Session.get('spaceId');\n  } else {\n    if (!spaceId) {\n      throw new Meteor.Error(400, 'miss spaceId');\n    }\n  }\n  su = Creator.getCollection('space_users').findOne({\n    space: spaceId,\n    user: userId\n  }, {\n    fields: {\n      company_ids: 1\n    }\n  });\n  return su != null ? su.company_ids : void 0;\n};\n\nCreator.processPermissions = function(po) {\n  if (po.allowCreate) {\n    po.allowRead = true;\n  }\n  if (po.allowEdit) {\n    po.allowRead = true;\n  }\n  if (po.allowDelete) {\n    po.allowEdit = true;\n    po.allowRead = true;\n  }\n  if (po.viewAllRecords) {\n    po.allowRead = true;\n  }\n  if (po.modifyAllRecords) {\n    po.allowRead = true;\n    po.allowEdit = true;\n    po.allowDelete = true;\n    po.viewAllRecords = true;\n  }\n  if (po.viewCompanyRecords) {\n    po.allowRead = true;\n  }\n  if (po.modifyCompanyRecords) {\n    po.allowRead = true;\n    po.allowEdit = true;\n    po.allowDelete = true;\n    po.viewCompanyRecords = true;\n  }\n  if (po.allowRead) {\n    typeof po.allowReadFiles !== \"boolean\" && (po.allowReadFiles = true);\n    typeof po.viewAllFiles !== \"boolean\" && (po.viewAllFiles = true);\n  }\n  if (po.allowEdit) {\n    typeof po.allowCreateFiles !== \"boolean\" && (po.allowCreateFiles = true);\n    typeof po.allowEditFiles !== \"boolean\" && (po.allowEditFiles = true);\n    typeof po.allowDeleteFiles !== \"boolean\" && (po.allowDeleteFiles = true);\n  }\n  if (po.modifyAllRecords) {\n    typeof po.modifyAllFiles !== \"boolean\" && (po.modifyAllFiles = true);\n  }\n  if (po.allowCreateFiles) {\n    po.allowReadFiles = true;\n  }\n  if (po.allowEditFiles) {\n    po.allowReadFiles = true;\n  }\n  if (po.allowDeleteFiles) {\n    po.allowEditFiles = true;\n    po.allowReadFiles = true;\n  }\n  if (po.viewAllFiles) {\n    po.allowReadFiles = true;\n  }\n  if (po.modifyAllFiles) {\n    po.allowReadFiles = true;\n    po.allowEditFiles = true;\n    po.allowDeleteFiles = true;\n    po.viewAllFiles = true;\n  }\n  return po;\n};\n\nCreator.getTemplateSpaceId = function() {\n  var ref;\n  return (ref = Meteor.settings[\"public\"]) != null ? ref.templateSpaceId : void 0;\n};\n\nCreator.getCloudAdminSpaceId = function() {\n  var ref;\n  return (ref = Meteor.settings[\"public\"]) != null ? ref.cloudAdminSpaceId : void 0;\n};\n\nCreator.isTemplateSpace = function(spaceId) {\n  var ref;\n  if (spaceId && ((ref = Meteor.settings[\"public\"]) != null ? ref.templateSpaceId : void 0) === spaceId) {\n    return true;\n  }\n  return false;\n};\n\nCreator.isCloudAdminSpace = function(spaceId) {\n  var ref;\n  if (spaceId && ((ref = Meteor.settings[\"public\"]) != null ? ref.cloudAdminSpaceId : void 0) === spaceId) {\n    return true;\n  }\n  return false;\n};\n\nif (Meteor.isServer) {\n  Creator.steedosStorageDir = process.env.STEEDOS_STORAGE_DIR;\n}\n","Meteor.methods\n\t# 用户获取lookup 、master_detail类型字段的选项值\n\t\"creator.object_options\": (options)->\n\t\tif options?.params?.reference_to\n\n\t\t\tobject = Creator.getObject(options.params.reference_to, options.params.space)\n\n\t\t\tname_field_key = object.NAME_FIELD_KEY\n\n\t\t\tquery = {}\n\t\t\tif options.params.space\n\t\t\t\tquery.space = options.params.space\n\n\t\t\t\tsort = options?.sort\n\n\t\t\t\tselected = options?.selected || []\n\n\t\t\t\toptions_limit = options?.options_limit || 10\n\n\t\t\t\tif options.searchText\n\t\t\t\t\tsearchTextQuery = {}\n\t\t\t\t\tsearchTextQuery[name_field_key] = {$regex: options.searchText}\n\n\t\t\t\tif options?.values?.length\n\t\t\t\t\tif options.searchText\n\t\t\t\t\t\tquery.$or = [{_id: {$in: options.values}}, searchTextQuery]\n\t\t\t\t\telse\n\t\t\t\t\t\tquery.$or = [{_id: {$in: options.values}}]\n\t\t\t\telse\n\t\t\t\t\tif options.searchText\n\t\t\t\t\t\t_.extend(query, searchTextQuery)\n\t\t\t\t\tquery._id = {$nin: selected}\n\n\t\t\t\tcollection = object.db\n\n\t\t\t\tif options.filterQuery\n\t\t\t\t\t_.extend query, options.filterQuery\n\n\t\t\t\tquery_options = {limit: options_limit}\n\n\t\t\t\tif sort && _.isObject(sort)\n\t\t\t\t\tquery_options.sort = sort\n\n\t\t\t\tif collection\n\t\t\t\t\ttry\n\t\t\t\t\t\trecords = collection.find(query, query_options).fetch()\n\t\t\t\t\t\tresults = []\n\t\t\t\t\t\t_.each records, (record)->\n\t\t\t\t\t\t\tresults.push\n\t\t\t\t\t\t\t\tlabel: record[name_field_key]\n\t\t\t\t\t\t\t\tvalue: record._id\n\t\t\t\t\t\treturn results\n\t\t\t\t\tcatch e\n\t\t\t\t\t\tthrow new Meteor.Error 500, e.message + \"-->\" + JSON.stringify(options)\n\t\treturn [] ","Meteor.methods({\n  \"creator.object_options\": function(options) {\n    var collection, e, name_field_key, object, options_limit, query, query_options, records, ref, ref1, results, searchTextQuery, selected, sort;\n    if (options != null ? (ref = options.params) != null ? ref.reference_to : void 0 : void 0) {\n      object = Creator.getObject(options.params.reference_to, options.params.space);\n      name_field_key = object.NAME_FIELD_KEY;\n      query = {};\n      if (options.params.space) {\n        query.space = options.params.space;\n        sort = options != null ? options.sort : void 0;\n        selected = (options != null ? options.selected : void 0) || [];\n        options_limit = (options != null ? options.options_limit : void 0) || 10;\n        if (options.searchText) {\n          searchTextQuery = {};\n          searchTextQuery[name_field_key] = {\n            $regex: options.searchText\n          };\n        }\n        if (options != null ? (ref1 = options.values) != null ? ref1.length : void 0 : void 0) {\n          if (options.searchText) {\n            query.$or = [\n              {\n                _id: {\n                  $in: options.values\n                }\n              }, searchTextQuery\n            ];\n          } else {\n            query.$or = [\n              {\n                _id: {\n                  $in: options.values\n                }\n              }\n            ];\n          }\n        } else {\n          if (options.searchText) {\n            _.extend(query, searchTextQuery);\n          }\n          query._id = {\n            $nin: selected\n          };\n        }\n        collection = object.db;\n        if (options.filterQuery) {\n          _.extend(query, options.filterQuery);\n        }\n        query_options = {\n          limit: options_limit\n        };\n        if (sort && _.isObject(sort)) {\n          query_options.sort = sort;\n        }\n        if (collection) {\n          try {\n            records = collection.find(query, query_options).fetch();\n            results = [];\n            _.each(records, function(record) {\n              return results.push({\n                label: record[name_field_key],\n                value: record._id\n              });\n            });\n            return results;\n          } catch (error) {\n            e = error;\n            throw new Meteor.Error(500, e.message + \"-->\" + JSON.stringify(options));\n          }\n        }\n      }\n    }\n    return [];\n  }\n});\n","Creator.getInitWidthPercent = (object_name, columns) ->\n\t_schema = Creator.getSchema(object_name)?._schema\n\tcolumn_num = 0\n\tif _schema\n\t\t_.each columns, (field_name) ->\n\t\t\tfield = _.pick(_schema, field_name)\n\t\t\tis_wide = field[field_name]?.autoform?.is_wide\n\t\t\tif is_wide\n\t\t\t\tcolumn_num += 2\n\t\t\telse\n\t\t\t\tcolumn_num += 1\n\n\t\tinit_width_percent = 100 / column_num\n\t\treturn init_width_percent\n\nCreator.getFieldIsWide = (object_name, field_name) ->\n\t_schema = Creator.getSchema(object_name)._schema\n\tif _schema\n\t\tfield = _.pick(_schema, field_name)\n\t\tis_wide = field[field_name]?.autoform?.is_wide\n\t\treturn is_wide\n\nCreator.getTabularOrder = (object_name, list_view_id, columns) ->\n\tsetting = Creator.Collections?.settings?.findOne({object_name: object_name, record_id: \"object_listviews\"})\n\tobj = Creator.getObject(object_name)\n\tcolumns = _.map columns, (column)->\n\t\tfield = obj.fields[column]\n\t\tif field?.type and !field.hidden\n\t\t\treturn column\n\t\telse\n\t\t\treturn undefined\n\tcolumns = _.compact columns\n\tif setting and setting.settings\n\t\tsort = setting.settings[list_view_id]?.sort || []\n\t\tsort = _.map sort, (order)->\n\t\t\tkey = order[0]\n\t\t\tindex = _.indexOf(columns, key)\n\t\t\torder[0] = index + 1\n\t\t\treturn order\n\t\treturn sort\n\treturn []\n\n\nCreator.initListViews = (object_name)->\n\tobject = Creator.getObject(object_name)\n\tcolumns = Creator.getObjectDefaultColumns(object_name) || [\"name\"]\n\textra_columns = [\"owner\"]\n\tdefault_extra_columns = Creator.getObjectDefaultExtraColumns(object_name) || [\"owner\"]\n\tif default_extra_columns\n\t\textra_columns = _.union extra_columns, default_extra_columns\n\n\torder = Creator.getObjectDefaultSort(object_name) || []\n\tif Meteor.isClient\n\t\tCreator.TabularSelectedIds?[object_name] = []\n\nCreator.convertListView = (default_view, list_view, list_view_name)->\n\tdefault_columns = default_view?.columns\n\tdefault_mobile_columns = default_view?.mobile_columns\n\tunless list_view\n\t\treturn\n\toitem = _.clone(list_view)\n\tif !_.has(oitem, \"name\")\n\t\toitem.name = list_view_name\n\tif !oitem.columns\n\t\tif default_columns\n\t\t\toitem.columns = default_columns\n\tif !oitem.columns\n\t\toitem.columns = [\"name\"]\n\tif !oitem.mobile_columns\n\t\tif default_mobile_columns\n\t\t\toitem.mobile_columns = default_mobile_columns\n\n\tif Meteor.isClient\n\t\tif Creator.isCloudAdminSpace(Session.get(\"spaceId\")) && !_.include(oitem.columns, 'space')\n\t\t\toitem.columns.push('space')\n\n\n\tif !oitem.filter_scope\n\t\t# listview视图的filter_scope默认值改为space #131\n\t\toitem.filter_scope = \"space\"\n\n\tif !_.has(oitem, \"_id\")\n\t\toitem._id = list_view_name\n\telse\n\t\toitem.label = oitem.label || list_view.name\n\n\tif _.isString(oitem.options)\n\t\toitem.options = JSON.parse(oitem.options)\n\n\t_.forEach oitem.filters, (filter, _index)->\n\t\tif !_.isArray(filter) && _.isObject(filter)\n\t\t\tif Meteor.isServer\n\t\t\t\tif _.isFunction(filter?.value)\n\t\t\t\t\tfilter._value = filter.value.toString()\n\t\t\telse\n\t\t\t\tif _.isString(filter?._value)\n\t\t\t\t\tfilter.value = Creator.eval(\"(#{filter._value})\")\n\treturn oitem\n\n\nif Meteor.isClient\n\tCreator.getRelatedList = (object_name)->\n\t\tunless object_name\n\t\t\treturn\n\t\trelatedListObjects = {}\n\t\trelatedListNames = []\n\t\tobjectLayoutRelatedListObjects = [];\n\t\t_object = Creator.getObject(object_name)\n\t\tif _object\n\t\t\tlayoutRelatedList = _object.related_lists;\n\t\t\t# layoutRelatedList 是数组就表示配置过页面布局，就启用页面布局的相关子表。\n\t\t\tif _.isArray layoutRelatedList\n\t\t\t\t_.each layoutRelatedList, (item)->\n\t\t\t\t\treObjectName = item.related_field_fullname.split('.')[0]\n\t\t\t\t\treFieldName = item.related_field_fullname.split('.')[1]\n\t\t\t\t\twrite_requires_master_read = Creator.getObject(reObjectName)?.fields[reFieldName]?.write_requires_master_read\n\t\t\t\t\trelated =\n\t\t\t\t\t\tobject_name: reObjectName\n\t\t\t\t\t\tcolumns: item.field_names\n\t\t\t\t\t\tmobile_columns: item.field_names\n\t\t\t\t\t\tis_file: reObjectName == \"cms_files\"\n\t\t\t\t\t\tfiltersFunction: item.filters\n\t\t\t\t\t\tsort: item.sort\n\t\t\t\t\t\trelated_field_name: reFieldName\n\t\t\t\t\t\tcustomRelatedListObject: true\n\t\t\t\t\t\twrite_requires_master_read: write_requires_master_read\n\t\t\t\t\t\tlabel: item.label\n\t\t\t\t\t\tactions: item.buttons\n\t\t\t\t\t\tvisible_on: item.visible_on\n\t\t\t\t\t\tpage_size: item.page_size\n\t\t\t\t\tobjectLayoutRelatedListObjects.push(related)\n\t\t\t\treturn objectLayoutRelatedListObjects;\n\t\t\trelatedList = _object.relatedList\n\t\t\tif !_.isEmpty relatedList\n\t\t\t\t_.each relatedList, (objOrName)->\n\t\t\t\t\tif _.isObject objOrName\n\t\t\t\t\t\trelated =\n\t\t\t\t\t\t\tobject_name: objOrName.objectName\n\t\t\t\t\t\t\tcolumns: objOrName.columns\n\t\t\t\t\t\t\tmobile_columns: objOrName.mobile_columns\n\t\t\t\t\t\t\tis_file: objOrName.objectName == \"cms_files\"\n\t\t\t\t\t\t\tfiltersFunction: objOrName.filters\n\t\t\t\t\t\t\tsort: objOrName.sort\n\t\t\t\t\t\t\trelated_field_name: ''\n\t\t\t\t\t\t\tcustomRelatedListObject: true\n\t\t\t\t\t\t\tlabel: objOrName.label\n\t\t\t\t\t\t\tactions: objOrName.actions\n\t\t\t\t\t\t\tpage_size: objOrName.page_size\n\t\t\t\t\t\trelatedListObjects[objOrName.objectName] = related\n\t\t\t\t\t\trelatedListNames.push objOrName.objectName\n\t\t\t\t\telse if _.isString objOrName\n\t\t\t\t\t\trelatedListNames.push objOrName\n\n\t\tmapList = {}\n\t\trelated_objects = Creator.getRelatedObjects(object_name)\n\t\t_.each related_objects, (related_object_item) ->\n\t\t\tif !related_object_item?.object_name\n\t\t\t\treturn\n\t\t\trelated_object_name = related_object_item.object_name\n\t\t\trelated_field_name = related_object_item.foreign_key\n\t\t\twrite_requires_master_read = related_object_item.write_requires_master_read\n\t\t\trelated_object = Creator.getObject(related_object_name)\n\t\t\tunless related_object\n\t\t\t\treturn\n\t\t\tcolumns = Creator.getObjectFirstListViewColumns(related_object_name) || [\"name\"]\n\t\t\tcolumns = _.without(columns, related_field_name)\n\t\t\tmobile_columns = Creator.getObjectFirstListViewColumns(related_object_name, true) || [\"name\"]\n\t\t\tmobile_columns = _.without(mobile_columns, related_field_name)\n\n\t\t\torder = Creator.getObjectDefaultSort(related_object_name)\n\t\t\ttabular_order = Creator.transformSortToTabular(order, columns)\n\n\t\t\tif /\\w+\\.\\$\\.\\w+/g.test(related_field_name)\n\t\t\t\t# object类型带子属性的related_field_name要去掉中间的美元符号，否则显示不出字段值\n\t\t\t\trelated_field_name = related_field_name.replace(/\\$\\./,\"\")\n\t\t\trelated =\n\t\t\t\tobject_name: related_object_name\n\t\t\t\tcolumns: columns\n\t\t\t\tmobile_columns: mobile_columns\n\t\t\t\trelated_field_name: related_field_name\n\t\t\t\tis_file: related_object_name == \"cms_files\"\n\t\t\t\twrite_requires_master_read: write_requires_master_read\n\n\t\t\trelatedObject = relatedListObjects[related_object_name]\n\t\t\tif relatedObject\n\t\t\t\tif relatedObject.columns\n\t\t\t\t\trelated.columns = relatedObject.columns\n\t\t\t\tif relatedObject.mobile_columns\n\t\t\t\t\trelated.mobile_columns = relatedObject.mobile_columns\n\t\t\t\tif relatedObject.sort\n\t\t\t\t\trelated.sort = relatedObject.sort\n\t\t\t\tif relatedObject.filtersFunction\n\t\t\t\t\trelated.filtersFunction = relatedObject.filtersFunction\n\t\t\t\tif relatedObject.customRelatedListObject\n\t\t\t\t\trelated.customRelatedListObject = relatedObject.customRelatedListObject\n\t\t\t\tif relatedObject.label\n\t\t\t\t\trelated.label = relatedObject.label\n\t\t\t\tif relatedObject.page_size\n\t\t\t\t\trelated.page_size = relatedObject.page_size\n\t\t\t\tdelete relatedListObjects[related_object_name]\n\n\t\t\tmapList[related.object_name] = related\n\n\n\t\tspaceId = Session.get(\"spaceId\")\n\t\tuserId = Meteor.userId()\n\t\trelated_object_names = _.pluck(_.values(relatedListObjects), \"object_name\")\n\t\tpermissions = Creator.getPermissions(object_name, spaceId, userId)\n\t\tunrelated_objects = permissions.unrelated_objects\n\t\trelated_object_names = _.difference related_object_names, unrelated_objects\n\t\t_.each relatedListObjects, (v, related_object_name) ->\n\t\t\tisActive = related_object_names.indexOf(related_object_name) > -1\n\t\t\tallowRead = Creator.getPermissions(related_object_name, spaceId, userId)?.allowRead\n\t\t\tif isActive && allowRead\n\t\t\t\tmapList[related_object_name] = v\n\n\t\tlist = []\n\t\tif _.isEmpty relatedListNames\n\t\t\tlist =  _.values mapList\n\t\telse\n\t\t\t_.each relatedListNames, (objectName) ->\n\t\t\t\tif mapList[objectName]\n\t\t\t\t\tlist.push mapList[objectName]\n\n\t\tif _.has(_object, 'allow_relatedList')\n\t\t\tlist = _.filter list, (item)->\n\t\t\t\treturn _.include(_object.allow_relatedList, item.object_name)\n\n\t\treturn list\n\nCreator.getObjectFirstListView = (object_name)->\n\treturn _.first(Creator.getListViews(object_name))\n\n### \n\t取出list_view_id对应的视图，如果不存在或者没有权限，就返回第一个视图\n\texac为true时，需要强制按list_view_id精确查找，不默认返回第一个视图\n###\nCreator.getListView = (object_name, list_view_id, exac)->\n\tif Meteor.isClient\n\t\tif !object_name\n\t\t\tobject_name = Session.get(\"object_name\")\n\t\tif !list_view_id\n\t\t\tlist_view_id = Session.get(\"list_view_id\")\n\tobject = Creator.getObject(object_name)\n\tif !object\n\t\treturn\n\tlistViews = Creator.getListViews(object_name)\n\tunless listViews?.length\n\t\treturn\n\tlist_view = _.find(listViews, (item)-> return item._id == list_view_id || item.name == list_view_id)\n\tunless list_view\n\t\t# 如果不需要强制按list_view_id精确查找，则默认返回第一个视图，反之返回空\n\t\tif exac\n\t\t\treturn\n\t\telse\n\t\t\tlist_view = listViews[0]\n\treturn list_view\n\n#获取list_view_id对应的视图是否是最近查看视图\nCreator.getListViewIsRecent = (object_name, list_view_id)->\n\tif Meteor.isClient\n\t\tif !object_name\n\t\t\tobject_name = Session.get(\"object_name\")\n\t\tif !list_view_id\n\t\t\tlist_view_id = Session.get(\"list_view_id\")\n\tif typeof(list_view_id) == \"string\"\n\t\tobject = Creator.getObject(object_name)\n\t\tif !object\n\t\t\treturn\n\t\tlistView = _.findWhere(object.list_views,{_id: list_view_id})\n\telse\n\t\tlistView = list_view_id\n\treturn listView?.name == \"recent\"\n\n\n###\n    从columns参数中过滤出用于手机端显示的columns\n\t规则：\n\t1.优先把columns中的name字段排在第一个\n\t2.最多只返回4个字段\n\t3.考虑宽字段占用整行规则条件下，最多只返回两行\n###\nCreator.pickObjectMobileColumns = (object_name, columns)->\n\tresult = []\n\tmaxRows = 2 \n\tmaxCount = maxRows * 2\n\tcount = 0\n\tobject = Creator.getObject(object_name)\n\tfields = object.fields\n\tunless object\n\t\treturn columns\n\tnameKey = object.NAME_FIELD_KEY\n\tisNameColumn = (item)->\n\t\tif _.isObject(item)\n\t\t\treturn item.field == nameKey\n\t\telse\n\t\t\treturn item == nameKey\n\tgetField = (item)->\n\t\tif _.isObject(item)\n\t\t\treturn fields[item.field]\n\t\telse\n\t\t\treturn fields[item]\n\tif nameKey\n\t\tnameColumn = columns.find (item)->\n\t\t\treturn isNameColumn(item)\n\tif nameColumn\n\t\tfield = getField(nameColumn)\n\t\titemCount = if field.is_wide then 2 else 1\n\t\tcount += itemCount\n\t\tresult.push nameColumn\n\tcolumns.forEach (item)->\n\t\tfield = getField(item)\n\t\tunless field\n\t\t\treturn\n\t\titemCount = if field.is_wide then 2 else 1\n\t\tif count < maxCount and result.length < maxCount and !isNameColumn(item)\n\t\t\tcount += itemCount\n\t\t\tif count <= maxCount\n\t\t\t\tresult.push item\n\t\n\treturn result\n\n###\n    获取默认视图\n###\nCreator.getObjectDefaultView = (object_name)->\n\tobject = Creator.getObject(object_name)\n\tif !object\n\t\tobject = Creator.Objects[object_name]\n\tif object?.list_views?.default\n\t\t#TODO 此代码只是暂时兼容以前code中定义的default视图，待code中的default清理完成后，需要删除此代码\n\t\tdefaultView = object.list_views.default\n\telse\n\t\t_.each object?.list_views, (list_view, key)->\n\t\t\tif list_view.name == \"all\" || key == \"all\"\n\t\t\t\tdefaultView = list_view\n\treturn defaultView;\n\n###\n    获取对象的列表默认显示字段\n###\nCreator.getObjectDefaultColumns = (object_name, use_mobile_columns)->\n\tdefaultView = Creator.getObjectDefaultView(object_name)\n\tcolumns = defaultView?.columns\n\tif use_mobile_columns\n\t\tif defaultView?.mobile_columns\n\t\t\tcolumns = defaultView.mobile_columns\n\t\telse if columns\n\t\t\tcolumns = Creator.pickObjectMobileColumns(object_name, columns)\n\treturn columns\n\n###\n    获取对象的列表第一个视图显示的字段\n###\nCreator.getObjectFirstListViewColumns = (object_name, use_mobile_columns)->\n\tdefaultView = Creator.getObjectFirstListView(object_name)\n\tcolumns = defaultView?.columns\n\tif use_mobile_columns\n\t\tif defaultView?.mobile_columns\n\t\t\tcolumns = defaultView.mobile_columns\n\t\telse if columns\n\t\t\tcolumns = Creator.pickObjectMobileColumns(object_name, columns)\n\treturn columns\n\n###\n\t获取对象的列表默认额外加载的字段\n###\nCreator.getObjectDefaultExtraColumns = (object_name)->\n\tdefaultView = Creator.getObjectDefaultView(object_name)\n\treturn defaultView?.extra_columns\n\n###\n\t获取对象的默认排序\n###\nCreator.getObjectDefaultSort = (object_name)->\n\tdefaultView = Creator.getObjectDefaultView(object_name)\n\tif defaultView\n\t\tif defaultView.sort\n\t\t\treturn defaultView.sort\n\t\telse\n\t\t\treturn [[\"created\", \"desc\"]]\n\n\n###\n    判断是否All view\n###\nCreator.isAllView = (list_view)->\n\treturn list_view?.name == \"all\"\n\n###\n    判断是否最近查看 view\n###\nCreator.isRecentView = (list_view)->\n\treturn list_view?.name == \"recent\"\n\n###\n    将sort转换为Tabular控件所需要的格式\n###\nCreator.transformSortToTabular = (sort, tabularColumns)->\n\ttabular_sort = []\n\t_.each sort, (item)->\n\t\tif _.isArray(item)\n\t\t\t# 兼容旧的数据格式[[\"field_name\", \"order\"]]\n\t\t\tif item.length == 1\n\t\t\t\tcolumn_index = tabularColumns.indexOf(item[0])\n\t\t\t\tif column_index > -1\n\t\t\t\t\ttabular_sort.push [column_index, \"asc\"]\n\t\t\telse if item.length == 2\n\t\t\t\tcolumn_index = tabularColumns.indexOf(item[0])\n\t\t\t\tif column_index > -1\n\t\t\t\t\ttabular_sort.push [column_index, item[1]]\n\t\telse if _.isObject(item)\n\t\t\t#新数据格式：[{field_name: , order: }]\n\t\t\tfield_name = item.field_name\n\t\t\torder = item.order\n\t\t\tif field_name && order\n\t\t\t\tcolumn_index = tabularColumns.indexOf(field_name)\n\t\t\t\tif column_index > -1\n\t\t\t\t\ttabular_sort.push [column_index, order]\n\n\treturn tabular_sort\n\n###\n    将sort转换为DevExpress控件所需要的格式\n###\nCreator.transformSortToDX = (sort)->\n\tdx_sort = []\n\t_.each sort, (item)->\n\t\tif _.isArray(item)\n\t\t\t#兼容旧格式：[[\"field_name\", \"order\"]]\n\t\t\tdx_sort.push(item)\n\t\telse if _.isObject(item)\n\t\t\t#新数据格式：[{field_name: , order: }]\n\t\t\tfield_name = item.field_name\n\t\t\torder = item.order\n\t\t\tif field_name && order\n\t\t\t\tdx_sort.push [field_name, order]\n\n\treturn dx_sort\n","Creator.getInitWidthPercent = function(object_name, columns) {\n  var _schema, column_num, init_width_percent, ref;\n  _schema = (ref = Creator.getSchema(object_name)) != null ? ref._schema : void 0;\n  column_num = 0;\n  if (_schema) {\n    _.each(columns, function(field_name) {\n      var field, is_wide, ref1, ref2;\n      field = _.pick(_schema, field_name);\n      is_wide = (ref1 = field[field_name]) != null ? (ref2 = ref1.autoform) != null ? ref2.is_wide : void 0 : void 0;\n      if (is_wide) {\n        return column_num += 2;\n      } else {\n        return column_num += 1;\n      }\n    });\n    init_width_percent = 100 / column_num;\n    return init_width_percent;\n  }\n};\n\nCreator.getFieldIsWide = function(object_name, field_name) {\n  var _schema, field, is_wide, ref, ref1;\n  _schema = Creator.getSchema(object_name)._schema;\n  if (_schema) {\n    field = _.pick(_schema, field_name);\n    is_wide = (ref = field[field_name]) != null ? (ref1 = ref.autoform) != null ? ref1.is_wide : void 0 : void 0;\n    return is_wide;\n  }\n};\n\nCreator.getTabularOrder = function(object_name, list_view_id, columns) {\n  var obj, ref, ref1, ref2, setting, sort;\n  setting = (ref = Creator.Collections) != null ? (ref1 = ref.settings) != null ? ref1.findOne({\n    object_name: object_name,\n    record_id: \"object_listviews\"\n  }) : void 0 : void 0;\n  obj = Creator.getObject(object_name);\n  columns = _.map(columns, function(column) {\n    var field;\n    field = obj.fields[column];\n    if ((field != null ? field.type : void 0) && !field.hidden) {\n      return column;\n    } else {\n      return void 0;\n    }\n  });\n  columns = _.compact(columns);\n  if (setting && setting.settings) {\n    sort = ((ref2 = setting.settings[list_view_id]) != null ? ref2.sort : void 0) || [];\n    sort = _.map(sort, function(order) {\n      var index, key;\n      key = order[0];\n      index = _.indexOf(columns, key);\n      order[0] = index + 1;\n      return order;\n    });\n    return sort;\n  }\n  return [];\n};\n\nCreator.initListViews = function(object_name) {\n  var columns, default_extra_columns, extra_columns, object, order, ref;\n  object = Creator.getObject(object_name);\n  columns = Creator.getObjectDefaultColumns(object_name) || [\"name\"];\n  extra_columns = [\"owner\"];\n  default_extra_columns = Creator.getObjectDefaultExtraColumns(object_name) || [\"owner\"];\n  if (default_extra_columns) {\n    extra_columns = _.union(extra_columns, default_extra_columns);\n  }\n  order = Creator.getObjectDefaultSort(object_name) || [];\n  if (Meteor.isClient) {\n    return (ref = Creator.TabularSelectedIds) != null ? ref[object_name] = [] : void 0;\n  }\n};\n\nCreator.convertListView = function(default_view, list_view, list_view_name) {\n  var default_columns, default_mobile_columns, oitem;\n  default_columns = default_view != null ? default_view.columns : void 0;\n  default_mobile_columns = default_view != null ? default_view.mobile_columns : void 0;\n  if (!list_view) {\n    return;\n  }\n  oitem = _.clone(list_view);\n  if (!_.has(oitem, \"name\")) {\n    oitem.name = list_view_name;\n  }\n  if (!oitem.columns) {\n    if (default_columns) {\n      oitem.columns = default_columns;\n    }\n  }\n  if (!oitem.columns) {\n    oitem.columns = [\"name\"];\n  }\n  if (!oitem.mobile_columns) {\n    if (default_mobile_columns) {\n      oitem.mobile_columns = default_mobile_columns;\n    }\n  }\n  if (Meteor.isClient) {\n    if (Creator.isCloudAdminSpace(Session.get(\"spaceId\")) && !_.include(oitem.columns, 'space')) {\n      oitem.columns.push('space');\n    }\n  }\n  if (!oitem.filter_scope) {\n    oitem.filter_scope = \"space\";\n  }\n  if (!_.has(oitem, \"_id\")) {\n    oitem._id = list_view_name;\n  } else {\n    oitem.label = oitem.label || list_view.name;\n  }\n  if (_.isString(oitem.options)) {\n    oitem.options = JSON.parse(oitem.options);\n  }\n  _.forEach(oitem.filters, function(filter, _index) {\n    if (!_.isArray(filter) && _.isObject(filter)) {\n      if (Meteor.isServer) {\n        if (_.isFunction(filter != null ? filter.value : void 0)) {\n          return filter._value = filter.value.toString();\n        }\n      } else {\n        if (_.isString(filter != null ? filter._value : void 0)) {\n          return filter.value = Creator[\"eval\"](\"(\" + filter._value + \")\");\n        }\n      }\n    }\n  });\n  return oitem;\n};\n\nif (Meteor.isClient) {\n  Creator.getRelatedList = function(object_name) {\n    var _object, layoutRelatedList, list, mapList, objectLayoutRelatedListObjects, permissions, relatedList, relatedListNames, relatedListObjects, related_object_names, related_objects, spaceId, unrelated_objects, userId;\n    if (!object_name) {\n      return;\n    }\n    relatedListObjects = {};\n    relatedListNames = [];\n    objectLayoutRelatedListObjects = [];\n    _object = Creator.getObject(object_name);\n    if (_object) {\n      layoutRelatedList = _object.related_lists;\n      if (_.isArray(layoutRelatedList)) {\n        _.each(layoutRelatedList, function(item) {\n          var reFieldName, reObjectName, ref, ref1, related, write_requires_master_read;\n          reObjectName = item.related_field_fullname.split('.')[0];\n          reFieldName = item.related_field_fullname.split('.')[1];\n          write_requires_master_read = (ref = Creator.getObject(reObjectName)) != null ? (ref1 = ref.fields[reFieldName]) != null ? ref1.write_requires_master_read : void 0 : void 0;\n          related = {\n            object_name: reObjectName,\n            columns: item.field_names,\n            mobile_columns: item.field_names,\n            is_file: reObjectName === \"cms_files\",\n            filtersFunction: item.filters,\n            sort: item.sort,\n            related_field_name: reFieldName,\n            customRelatedListObject: true,\n            write_requires_master_read: write_requires_master_read,\n            label: item.label,\n            actions: item.buttons,\n            visible_on: item.visible_on,\n            page_size: item.page_size\n          };\n          return objectLayoutRelatedListObjects.push(related);\n        });\n        return objectLayoutRelatedListObjects;\n      }\n      relatedList = _object.relatedList;\n      if (!_.isEmpty(relatedList)) {\n        _.each(relatedList, function(objOrName) {\n          var related;\n          if (_.isObject(objOrName)) {\n            related = {\n              object_name: objOrName.objectName,\n              columns: objOrName.columns,\n              mobile_columns: objOrName.mobile_columns,\n              is_file: objOrName.objectName === \"cms_files\",\n              filtersFunction: objOrName.filters,\n              sort: objOrName.sort,\n              related_field_name: '',\n              customRelatedListObject: true,\n              label: objOrName.label,\n              actions: objOrName.actions,\n              page_size: objOrName.page_size\n            };\n            relatedListObjects[objOrName.objectName] = related;\n            return relatedListNames.push(objOrName.objectName);\n          } else if (_.isString(objOrName)) {\n            return relatedListNames.push(objOrName);\n          }\n        });\n      }\n    }\n    mapList = {};\n    related_objects = Creator.getRelatedObjects(object_name);\n    _.each(related_objects, function(related_object_item) {\n      var columns, mobile_columns, order, related, relatedObject, related_field_name, related_object, related_object_name, tabular_order, write_requires_master_read;\n      if (!(related_object_item != null ? related_object_item.object_name : void 0)) {\n        return;\n      }\n      related_object_name = related_object_item.object_name;\n      related_field_name = related_object_item.foreign_key;\n      write_requires_master_read = related_object_item.write_requires_master_read;\n      related_object = Creator.getObject(related_object_name);\n      if (!related_object) {\n        return;\n      }\n      columns = Creator.getObjectFirstListViewColumns(related_object_name) || [\"name\"];\n      columns = _.without(columns, related_field_name);\n      mobile_columns = Creator.getObjectFirstListViewColumns(related_object_name, true) || [\"name\"];\n      mobile_columns = _.without(mobile_columns, related_field_name);\n      order = Creator.getObjectDefaultSort(related_object_name);\n      tabular_order = Creator.transformSortToTabular(order, columns);\n      if (/\\w+\\.\\$\\.\\w+/g.test(related_field_name)) {\n        related_field_name = related_field_name.replace(/\\$\\./, \"\");\n      }\n      related = {\n        object_name: related_object_name,\n        columns: columns,\n        mobile_columns: mobile_columns,\n        related_field_name: related_field_name,\n        is_file: related_object_name === \"cms_files\",\n        write_requires_master_read: write_requires_master_read\n      };\n      relatedObject = relatedListObjects[related_object_name];\n      if (relatedObject) {\n        if (relatedObject.columns) {\n          related.columns = relatedObject.columns;\n        }\n        if (relatedObject.mobile_columns) {\n          related.mobile_columns = relatedObject.mobile_columns;\n        }\n        if (relatedObject.sort) {\n          related.sort = relatedObject.sort;\n        }\n        if (relatedObject.filtersFunction) {\n          related.filtersFunction = relatedObject.filtersFunction;\n        }\n        if (relatedObject.customRelatedListObject) {\n          related.customRelatedListObject = relatedObject.customRelatedListObject;\n        }\n        if (relatedObject.label) {\n          related.label = relatedObject.label;\n        }\n        if (relatedObject.page_size) {\n          related.page_size = relatedObject.page_size;\n        }\n        delete relatedListObjects[related_object_name];\n      }\n      return mapList[related.object_name] = related;\n    });\n    spaceId = Session.get(\"spaceId\");\n    userId = Meteor.userId();\n    related_object_names = _.pluck(_.values(relatedListObjects), \"object_name\");\n    permissions = Creator.getPermissions(object_name, spaceId, userId);\n    unrelated_objects = permissions.unrelated_objects;\n    related_object_names = _.difference(related_object_names, unrelated_objects);\n    _.each(relatedListObjects, function(v, related_object_name) {\n      var allowRead, isActive, ref;\n      isActive = related_object_names.indexOf(related_object_name) > -1;\n      allowRead = (ref = Creator.getPermissions(related_object_name, spaceId, userId)) != null ? ref.allowRead : void 0;\n      if (isActive && allowRead) {\n        return mapList[related_object_name] = v;\n      }\n    });\n    list = [];\n    if (_.isEmpty(relatedListNames)) {\n      list = _.values(mapList);\n    } else {\n      _.each(relatedListNames, function(objectName) {\n        if (mapList[objectName]) {\n          return list.push(mapList[objectName]);\n        }\n      });\n    }\n    if (_.has(_object, 'allow_relatedList')) {\n      list = _.filter(list, function(item) {\n        return _.include(_object.allow_relatedList, item.object_name);\n      });\n    }\n    return list;\n  };\n}\n\nCreator.getObjectFirstListView = function(object_name) {\n  return _.first(Creator.getListViews(object_name));\n};\n\n\n/* \n\t取出list_view_id对应的视图，如果不存在或者没有权限，就返回第一个视图\n\texac为true时，需要强制按list_view_id精确查找，不默认返回第一个视图\n */\n\nCreator.getListView = function(object_name, list_view_id, exac) {\n  var listViews, list_view, object;\n  if (Meteor.isClient) {\n    if (!object_name) {\n      object_name = Session.get(\"object_name\");\n    }\n    if (!list_view_id) {\n      list_view_id = Session.get(\"list_view_id\");\n    }\n  }\n  object = Creator.getObject(object_name);\n  if (!object) {\n    return;\n  }\n  listViews = Creator.getListViews(object_name);\n  if (!(listViews != null ? listViews.length : void 0)) {\n    return;\n  }\n  list_view = _.find(listViews, function(item) {\n    return item._id === list_view_id || item.name === list_view_id;\n  });\n  if (!list_view) {\n    if (exac) {\n      return;\n    } else {\n      list_view = listViews[0];\n    }\n  }\n  return list_view;\n};\n\nCreator.getListViewIsRecent = function(object_name, list_view_id) {\n  var listView, object;\n  if (Meteor.isClient) {\n    if (!object_name) {\n      object_name = Session.get(\"object_name\");\n    }\n    if (!list_view_id) {\n      list_view_id = Session.get(\"list_view_id\");\n    }\n  }\n  if (typeof list_view_id === \"string\") {\n    object = Creator.getObject(object_name);\n    if (!object) {\n      return;\n    }\n    listView = _.findWhere(object.list_views, {\n      _id: list_view_id\n    });\n  } else {\n    listView = list_view_id;\n  }\n  return (listView != null ? listView.name : void 0) === \"recent\";\n};\n\n\n/*\n    从columns参数中过滤出用于手机端显示的columns\n\t规则：\n\t1.优先把columns中的name字段排在第一个\n\t2.最多只返回4个字段\n\t3.考虑宽字段占用整行规则条件下，最多只返回两行\n */\n\nCreator.pickObjectMobileColumns = function(object_name, columns) {\n  var count, field, fields, getField, isNameColumn, itemCount, maxCount, maxRows, nameColumn, nameKey, object, result;\n  result = [];\n  maxRows = 2;\n  maxCount = maxRows * 2;\n  count = 0;\n  object = Creator.getObject(object_name);\n  fields = object.fields;\n  if (!object) {\n    return columns;\n  }\n  nameKey = object.NAME_FIELD_KEY;\n  isNameColumn = function(item) {\n    if (_.isObject(item)) {\n      return item.field === nameKey;\n    } else {\n      return item === nameKey;\n    }\n  };\n  getField = function(item) {\n    if (_.isObject(item)) {\n      return fields[item.field];\n    } else {\n      return fields[item];\n    }\n  };\n  if (nameKey) {\n    nameColumn = columns.find(function(item) {\n      return isNameColumn(item);\n    });\n  }\n  if (nameColumn) {\n    field = getField(nameColumn);\n    itemCount = field.is_wide ? 2 : 1;\n    count += itemCount;\n    result.push(nameColumn);\n  }\n  columns.forEach(function(item) {\n    field = getField(item);\n    if (!field) {\n      return;\n    }\n    itemCount = field.is_wide ? 2 : 1;\n    if (count < maxCount && result.length < maxCount && !isNameColumn(item)) {\n      count += itemCount;\n      if (count <= maxCount) {\n        return result.push(item);\n      }\n    }\n  });\n  return result;\n};\n\n\n/*\n    获取默认视图\n */\n\nCreator.getObjectDefaultView = function(object_name) {\n  var defaultView, object, ref;\n  object = Creator.getObject(object_name);\n  if (!object) {\n    object = Creator.Objects[object_name];\n  }\n  if (object != null ? (ref = object.list_views) != null ? ref[\"default\"] : void 0 : void 0) {\n    defaultView = object.list_views[\"default\"];\n  } else {\n    _.each(object != null ? object.list_views : void 0, function(list_view, key) {\n      if (list_view.name === \"all\" || key === \"all\") {\n        return defaultView = list_view;\n      }\n    });\n  }\n  return defaultView;\n};\n\n\n/*\n    获取对象的列表默认显示字段\n */\n\nCreator.getObjectDefaultColumns = function(object_name, use_mobile_columns) {\n  var columns, defaultView;\n  defaultView = Creator.getObjectDefaultView(object_name);\n  columns = defaultView != null ? defaultView.columns : void 0;\n  if (use_mobile_columns) {\n    if (defaultView != null ? defaultView.mobile_columns : void 0) {\n      columns = defaultView.mobile_columns;\n    } else if (columns) {\n      columns = Creator.pickObjectMobileColumns(object_name, columns);\n    }\n  }\n  return columns;\n};\n\n\n/*\n    获取对象的列表第一个视图显示的字段\n */\n\nCreator.getObjectFirstListViewColumns = function(object_name, use_mobile_columns) {\n  var columns, defaultView;\n  defaultView = Creator.getObjectFirstListView(object_name);\n  columns = defaultView != null ? defaultView.columns : void 0;\n  if (use_mobile_columns) {\n    if (defaultView != null ? defaultView.mobile_columns : void 0) {\n      columns = defaultView.mobile_columns;\n    } else if (columns) {\n      columns = Creator.pickObjectMobileColumns(object_name, columns);\n    }\n  }\n  return columns;\n};\n\n\n/*\n\t获取对象的列表默认额外加载的字段\n */\n\nCreator.getObjectDefaultExtraColumns = function(object_name) {\n  var defaultView;\n  defaultView = Creator.getObjectDefaultView(object_name);\n  return defaultView != null ? defaultView.extra_columns : void 0;\n};\n\n\n/*\n\t获取对象的默认排序\n */\n\nCreator.getObjectDefaultSort = function(object_name) {\n  var defaultView;\n  defaultView = Creator.getObjectDefaultView(object_name);\n  if (defaultView) {\n    if (defaultView.sort) {\n      return defaultView.sort;\n    } else {\n      return [[\"created\", \"desc\"]];\n    }\n  }\n};\n\n\n/*\n    判断是否All view\n */\n\nCreator.isAllView = function(list_view) {\n  return (list_view != null ? list_view.name : void 0) === \"all\";\n};\n\n\n/*\n    判断是否最近查看 view\n */\n\nCreator.isRecentView = function(list_view) {\n  return (list_view != null ? list_view.name : void 0) === \"recent\";\n};\n\n\n/*\n    将sort转换为Tabular控件所需要的格式\n */\n\nCreator.transformSortToTabular = function(sort, tabularColumns) {\n  var tabular_sort;\n  tabular_sort = [];\n  _.each(sort, function(item) {\n    var column_index, field_name, order;\n    if (_.isArray(item)) {\n      if (item.length === 1) {\n        column_index = tabularColumns.indexOf(item[0]);\n        if (column_index > -1) {\n          return tabular_sort.push([column_index, \"asc\"]);\n        }\n      } else if (item.length === 2) {\n        column_index = tabularColumns.indexOf(item[0]);\n        if (column_index > -1) {\n          return tabular_sort.push([column_index, item[1]]);\n        }\n      }\n    } else if (_.isObject(item)) {\n      field_name = item.field_name;\n      order = item.order;\n      if (field_name && order) {\n        column_index = tabularColumns.indexOf(field_name);\n        if (column_index > -1) {\n          return tabular_sort.push([column_index, order]);\n        }\n      }\n    }\n  });\n  return tabular_sort;\n};\n\n\n/*\n    将sort转换为DevExpress控件所需要的格式\n */\n\nCreator.transformSortToDX = function(sort) {\n  var dx_sort;\n  dx_sort = [];\n  _.each(sort, function(item) {\n    var field_name, order;\n    if (_.isArray(item)) {\n      return dx_sort.push(item);\n    } else if (_.isObject(item)) {\n      field_name = item.field_name;\n      order = item.order;\n      if (field_name && order) {\n        return dx_sort.push([field_name, order]);\n      }\n    }\n  });\n  return dx_sort;\n};\n","SimpleSchema.RegEx.code = new RegExp('^[a-zA-Z_][a-zA-Z0-9_]*$')\n\nif Meteor.isClient\n\tMeteor.startup ()->\n\t\t_regExMessages = SimpleSchema._globalMessages.regEx || []\n\t\t_regExMessages.push {exp: SimpleSchema.RegEx.code, msg: \"[label] 只能以字母、_开头，且只能包含字母、数字、_\"}\n\t\tSimpleSchema.messages({\n\t\t\tregEx: _regExMessages,\n\t\t})","SimpleSchema.RegEx.code = new RegExp('^[a-zA-Z_][a-zA-Z0-9_]*$');\n\nif (Meteor.isClient) {\n  Meteor.startup(function() {\n    var _regExMessages;\n    _regExMessages = SimpleSchema._globalMessages.regEx || [];\n    _regExMessages.push({\n      exp: SimpleSchema.RegEx.code,\n      msg: \"[label] 只能以字母、_开头，且只能包含字母、数字、_\"\n    });\n    return SimpleSchema.messages({\n      regEx: _regExMessages\n    });\n  });\n}\n","SimpleSchema.RegEx.field = new RegExp('^[a-zA-Z_]\\\\w*(\\\\.\\\\$\\\\.\\\\w+)?[a-zA-Z0-9]*$')\n\nif Meteor.isClient\n\tMeteor.startup ()->\n\t\t_regExMessages = SimpleSchema._globalMessages.regEx || []\n\t\t_regExMessages.push {exp: SimpleSchema.RegEx.field, msg: \"[label] 只能以字母、_开头，.$.前后必须包含字符\"}\n\t\tSimpleSchema.messages({\n\t\t\tregEx: _regExMessages,\n\t\t})","SimpleSchema.RegEx.field = new RegExp('^[a-zA-Z_]\\\\w*(\\\\.\\\\$\\\\.\\\\w+)?[a-zA-Z0-9]*$');\n\nif (Meteor.isClient) {\n  Meteor.startup(function() {\n    var _regExMessages;\n    _regExMessages = SimpleSchema._globalMessages.regEx || [];\n    _regExMessages.push({\n      exp: SimpleSchema.RegEx.field,\n      msg: \"[label] 只能以字母、_开头，.$.前后必须包含字符\"\n    });\n    return SimpleSchema.messages({\n      regEx: _regExMessages\n    });\n  });\n}\n","// 因为meteor编译coffeescript会导致eval函数报错，所以单独写在一个js文件中。\nCreator.evalInContext = function(js, context) {\n    //# Return the results of the in-line anonymous function we .call with the passed context\n    return function() { \n    \treturn eval(js); \n\t}.call(context);\n}\n\n\nCreator.eval = function(js){\n\ttry{\n\t\treturn eval(js)\n\t}catch (e){\n\t\tconsole.error(e, js);\n\t}\n};","\tgetOption = (option)->\n\t\tfoo = option.split(\":\")\n\t\tif foo.length > 2\n\t\t\treturn {label: foo[0], value: foo[1], color: foo[2]}\n\t\telse if foo.length > 1\n\t\t\treturn {label: foo[0], value: foo[1]}\n\t\telse\n\t\t\treturn {label: foo[0], value: foo[0]}\n\n\tconvertField = (object_name, field_name, field, spaceId)->\n\t\tif Meteor.isServer && spaceId && field.type == 'select'\n\t\t\tcode = field.picklist || \"#{object_name}.#{field_name}\";\n\t\t\tif code\n\t\t\t\tpicklist = Creator.getPicklist(code, spaceId);\n\t\t\t\tif picklist\n\t\t\t\t\toptions = [];\n\t\t\t\t\tallOptions = [];\n\t\t\t\t\tpicklistOptions = Creator.getPickListOptions(picklist)\n\t\t\t\t\tpicklistOptions = _.sortBy(picklistOptions, 'sort_no')?.reverse();\n\t\t\t\t\t_.each picklistOptions, (item)->\n\t\t\t\t\t\tlabel = item.name\n\t\t\t\t\t\tvalue = item.value || item.name\n\t\t\t\t\t\tallOptions.push({label: label, value: value, enable: item.enable, color: item.color})\n\t\t\t\t\t\tif item.enable\n\t\t\t\t\t\t\toptions.push({label: label, value: value, color: item.color})\n\t\t\t\t\t\tif item.default\n\t\t\t\t\t\t\tfield.defaultValue = value\n\t\t\t\t\tif options.length > 0\n\t\t\t\t\t\tfield.options = options\n\t\t\t\t\tif allOptions.length > 0\n\t\t\t\t\t\tfield.allOptions = allOptions\n\t\treturn field;\n\n\tCreator.convertObject = (object, spaceId)->\n\t\tif !object\n\t\t\treturn\n\t\t_.forEach object.triggers, (trigger, key)->\n\n\t\t\tif (Meteor.isServer && trigger.on == \"server\") || (Meteor.isClient && trigger.on == \"client\")\n\t\t\t\t_todo_from_code = trigger?._todo\n\t\t\t\t_todo_from_db = trigger.todo\n\t\t\t\tif _todo_from_code && _.isString(_todo_from_code)\n\t\t\t\t\ttrigger.todo = Creator.eval(\"(#{_todo_from_code})\")\n\n\t\t\t\tif _todo_from_db && _.isString(_todo_from_db)\n\t\t\t\t\t#只有update时， fieldNames, modifier, options 才有值\n\t\t\t\t\t#TODO 控制可使用的变量，尤其是Collection\n\t\t\t\t\tif _todo_from_db.startsWith(\"function\")\n\t\t\t\t\t\ttrigger.todo = Creator.eval(\"(#{_todo_from_db})\")\n\t\t\t\t\telse\n\t\t\t\t\t\ttrigger.todo = Creator.eval(\"(function(userId, doc, fieldNames, modifier, options){#{_todo_from_db}})\")\n\n\t\t\tif Meteor.isServer && trigger.on == \"client\"\n\t\t\t\t_todo = trigger.todo\n\t\t\t\tif _todo && _.isFunction(_todo)\n\t\t\t\t\ttrigger._todo = _todo.toString()\n\n\t\tif Meteor.isClient\n\t\t\t_.forEach object.fields, (field, key)->\n\n\t\t\t\tif field.omit\n\t\t\t\t\t# omit字段完全隐藏不显示\n\t\t\t\t\tfield.hidden = true\n\n\t\t\t\tif field.required && field.readonly\n\t\t\t\t\t# 通用必填字段 #2952，必填字段设置为非只读\n\t\t\t\t\tfield.readonly = false\n\n\t\t\t\tsystemBaseFields = Creator.getSystemBaseFields()\n\t\t\t\tif systemBaseFields.indexOf(key) > -1\n\t\t\t\t\t# 强制创建人创建时间等字段为只读\n\t\t\t\t\tfield.readonly = true\n\n\t\t\t_.forEach object.actions, (action, key)->\n\t\t\t\t_todo_from_code = action?._todo\n\t\t\t\t_todo_from_db = action?.todo\n\t\t\t\tif _todo_from_code && _.isString(_todo_from_code)\n\t\t\t\t\t#TODO 控制可使用的变量\n\t\t\t\t\ttry\n\t\t\t\t\t\taction.todo = Creator.eval(\"(#{_todo_from_code})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"todo_from_code\", _todo_from_code\n\t\t\t\tif _todo_from_db && _.isString(_todo_from_db)\n\t\t\t\t\t#TODO 控制可使用的变量\n\t\t\t\t\ttry\n\t\t\t\t\t\tif _todo_from_db.startsWith(\"function\")\n\t\t\t\t\t\t\taction.todo = Creator.eval(\"(#{_todo_from_db})\")\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tif _.isFunction(Creator.actionsByName[_todo_from_db])\n\t\t\t\t\t\t\t\taction.todo = _todo_from_db\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\taction.todo = Creator.eval(\"(function(){#{_todo_from_db}})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"todo_from_db\", _todo_from_db, error\n\n\t\t\t\t_visible = action?._visible\n\t\t\t\tif _visible\n\t\t\t\t\ttry\n\t\t\t\t\t\tif _.isString(_visible)\n\t\t\t\t\t\t\t_visible = _visible.trim()\n\t\t\t\t\t\tif Steedos.isExpression(_visible)\n\t\t\t\t\t\t\t# 支持页面布局中写visible_on函数表达式，页面布局按钮的显示条件不生效 #3340\n\t\t\t\t\t\t\taction.visible = (object_name, record_id, record_permissions, record) ->\n\t\t\t\t\t\t\t\tglobalData = Object.assign({}, Creator.USER_CONTEXT, {now: new Date()})\n\t\t\t\t\t\t\t\treturn Steedos.parseSingleExpression(_visible, record, \"#\", globalData)\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\taction.visible = Creator.eval(\"(#{_visible})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"action.visible to function error: \", error, _visible\n\t\telse\n\t\t\t_.forEach object.actions, (action, key)->\n\t\t\t\t_todo = action?.todo\n\t\t\t\tif _todo && _.isFunction(_todo)\n\t\t\t\t\t#TODO 控制可使用的变量\n\t\t\t\t\taction._todo = _todo.toString()\n\n\t\t\t\t_visible = action?.visible\n\n\t\t\t\tif _visible && _.isFunction(_visible)\n\t\t\t\t\taction._visible = _visible.toString()\n\n\t\t_.forEach object.fields, (field, key)->\n\n\t\t\tfield = convertField(object.name, key, field, spaceId);\n\n\t\t\tif field.options && _.isString(field.options)\n\t\t\t\ttry\n\t\t\t\t\t_options = []\n\t\t\t\t\t#支持\\n或者英文逗号分割,\n\t\t\t\t\t_.forEach field.options.split(\"\\n\"), (option)->\n\t\t\t\t\t\tif option.indexOf(\",\")\n\t\t\t\t\t\t\toptions = option.split(\",\")\n\t\t\t\t\t\t\t_.forEach options, (_option)->\n\t\t\t\t\t\t\t\t_options.push(getOption(_option))\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t_options.push(getOption(option))\n\t\t\t\t\tfield.options = _options\n\t\t\t\tcatch error\n\t\t\t\t\tconsole.error \"Creator.convertFieldsOptions\", field.options, error\n\n\t\t\telse if field.options && _.isArray(field.options)\n\t\t\t\ttry\n\t\t\t\t\t_options = []\n\t\t\t\t\t#支持数组中直接定义每个选项的简版格式字符串\n\t\t\t\t\t_.forEach field.options, (option)->\n\t\t\t\t\t\tif _.isString(option)\n\t\t\t\t\t\t\t_options.push(getOption(option))\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t_options.push(option)\n\t\t\t\t\tfield.options = _options\n\t\t\t\tcatch error\n\t\t\t\t\tconsole.error \"Creator.convertFieldsOptions\", field.options, error\n\n\t\t\telse if field.options && !_.isFunction(field.options) && !_.isArray(field.options) && _.isObject(field.options)\n\t\t\t\t_options = []\n\t\t\t\t_.each field.options, (v, k)->\n\t\t\t\t\t_options.push {label: v, value: k}\n\t\t\t\tfield.options = _options\n\n\t\t\tif Meteor.isServer\n\t\t\t\toptions = field.options\n\t\t\t\tif options && _.isFunction(options)\n\t\t\t\t\tfield._options = field.options.toString()\n\t\t\telse\n\t\t\t\toptions = field._options\n\t\t\t\tif options && _.isString(options)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.options = Creator.eval(\"(#{options})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t\tif Meteor.isServer\n\t\t\t\tregEx = field.regEx\n\t\t\t\tif regEx\n\t\t\t\t\tfield._regEx = field.regEx.toString()\n\t\t\telse\n\t\t\t\tregEx = field._regEx\n\t\t\t\tif regEx\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.regEx = Creator.eval(\"(#{regEx})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t\tif Meteor.isServer\n\t\t\t\tmin = field.min\n\t\t\t\tif _.isFunction(min)\n\t\t\t\t\tfield._min = min.toString()\n\t\t\telse\n\t\t\t\tmin = field._min\n\t\t\t\tif _.isString(min)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.min = Creator.eval(\"(#{min})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t\tif Meteor.isServer\n\t\t\t\tmax = field.max\n\t\t\t\tif _.isFunction(max)\n\t\t\t\t\tfield._max = max.toString()\n\t\t\telse\n\t\t\t\tmax = field._max\n\t\t\t\tif _.isString(max)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.max = Creator.eval(\"(#{max})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t\tif Meteor.isServer\n\t\t\t\tif field.autoform\n\t\t\t\t\t_type = field.autoform.type\n\t\t\t\t\tif _type && _.isFunction(_type) && _type != Object && _type != String && _type != Number && _type != Boolean && !_.isArray(_type)\n\t\t\t\t\t\tfield.autoform._type = _type.toString()\n\t\t\telse\n\t\t\t\tif field.autoform\n\t\t\t\t\t_type = field.autoform._type\n\t\t\t\t\tif _type && _.isString(_type)\n\t\t\t\t\t\ttry\n\t\t\t\t\t\t\tfield.autoform.type = Creator.eval(\"(#{_type})\")\n\t\t\t\t\t\tcatch error\n\t\t\t\t\t\t\tconsole.error \"convert field -> type error\", field, error\n\n\t\t\tif Meteor.isServer\n\n\t\t\t\toptionsFunction = field.optionsFunction\n\t\t\t\treference_to = field.reference_to\n\t\t\t\tcreateFunction = field.createFunction\n\t\t\t\tbeforeOpenFunction = field.beforeOpenFunction\n\t\t\t\tfiltersFunction = field.filtersFunction\n\n\t\t\t\tif optionsFunction && _.isFunction(optionsFunction)\n\t\t\t\t\tfield._optionsFunction = optionsFunction.toString()\n\n\t\t\t\tif reference_to && _.isFunction(reference_to)\n\t\t\t\t\tfield._reference_to = reference_to.toString()\n\n\t\t\t\tif createFunction && _.isFunction(createFunction)\n\t\t\t\t\tfield._createFunction = createFunction.toString()\n\t\t\t\tif beforeOpenFunction && _.isFunction(beforeOpenFunction)\n\t\t\t\t\tfield._beforeOpenFunction = beforeOpenFunction.toString()\n\n\t\t\t\tif filtersFunction && _.isFunction(filtersFunction)\n\t\t\t\t\tfield._filtersFunction = filtersFunction.toString()\n\t\t\telse\n\n\t\t\t\toptionsFunction = field._optionsFunction || field.optionsFunction\n\t\t\t\treference_to = field._reference_to\n\t\t\t\tcreateFunction = field._createFunction\n\t\t\t\tbeforeOpenFunction = field._beforeOpenFunction\n\t\t\t\tfiltersFunction = field._filtersFunction || field.filtersFunction\n\n\t\t\t\tif optionsFunction && _.isString(optionsFunction)\n\t\t\t\t\tfield.optionsFunction = Creator.eval(\"(#{optionsFunction})\")\n\n\t\t\t\tif reference_to && _.isString(reference_to)\n\t\t\t\t\tfield.reference_to = Creator.eval(\"(#{reference_to})\")\n\n\t\t\t\tif createFunction && _.isString(createFunction)\n\t\t\t\t\tfield.createFunction = Creator.eval(\"(#{createFunction})\")\n\n\t\t\t\tif beforeOpenFunction && _.isString(beforeOpenFunction)\n\t\t\t\t\tfield.beforeOpenFunction = Creator.eval(\"(#{beforeOpenFunction})\")\n\n\t\t\t\tif filtersFunction && _.isString(filtersFunction)\n\t\t\t\t\tfield.filtersFunction = Creator.eval(\"(#{filtersFunction})\")\n\n\t\t\tif Meteor.isServer\n\t\t\t\tdefaultValue = field.defaultValue\n\t\t\t\tif defaultValue && _.isFunction(defaultValue)\n\t\t\t\t\tfield._defaultValue = field.defaultValue.toString()\n\t\t\telse\n\t\t\t\tdefaultValue = field._defaultValue\n\n\t\t\t\tif !defaultValue && _.isString(field.defaultValue) && field.defaultValue.startsWith(\"function\")\n\t\t\t\t\tdefaultValue = field.defaultValue\n\n\t\t\t\tif defaultValue && _.isString(defaultValue)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.defaultValue = Creator.eval(\"(#{defaultValue})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\t\t\t\n\t\t\tif Meteor.isServer\n\t\t\t\tis_company_limited = field.is_company_limited\n\t\t\t\tif is_company_limited && _.isFunction(is_company_limited)\n\t\t\t\t\tfield._is_company_limited = field.is_company_limited.toString()\n\t\t\telse\n\t\t\t\tis_company_limited = field._is_company_limited\n\t\t\t\tif is_company_limited && _.isString(is_company_limited)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.is_company_limited = Creator.eval(\"(#{is_company_limited})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t_.forEach object.list_views, (list_view, key) ->\n\t\t\t###\n\t\t\t视图过虑器需要支持function，后台转成字符串，前台eval成函数\n\t\t\t让过虑器支持两种function方式：\n\t\t\t1. 整个filters为function:\n\t\t\t如：\n\t\t\tfilters: ()->\n\t\t\t\treturn [[[\"object_name\",\"=\",\"project_issues\"],'or',[\"object_name\",\"=\",\"tasks\"]]]\n\t\t\t2. filters内的filter.value为function\n\t\t\t如：\n\t\t\tfilters: [[\"object_name\", \"=\", ()->\n\t\t\t\treturn \"project_issues\"\n\t\t\t]]\n\t\t\t或\n\t\t\tfilters: [{\n\t\t\t\t\"field\": \"object_name\"\n\t\t\t\t\"operation\": \"=\"\n\t\t\t\t\"value\": ()->\n\t\t\t\t\treturn \"project_issues\"\n\t\t\t}]\n\t\t\t###\n\t\t\tif _.isFunction(list_view.filters)\n\t\t\t\tif Meteor.isServer\n\t\t\t\t\tlist_view._filters = list_view.filters.toString()\n\t\t\telse if _.isString(list_view._filters)\n\t\t\t\tif Meteor.isClient\n\t\t\t\t\tlist_view.filters = Creator.eval(\"(#{list_view._filters})\")\n\t\t\telse\n\t\t\t\t_.forEach list_view.filters, (filter, _index)->\n\t\t\t\t\tif _.isArray(filter)\n\t\t\t\t\t\tif Meteor.isServer\n\t\t\t\t\t\t\tif filter.length == 3 and _.isFunction(filter[2])\n\t\t\t\t\t\t\t\tfilter[2] = filter[2].toString()\n\t\t\t\t\t\t\t\tfilter[3] = \"FUNCTION\"\n\t\t\t\t\t\t\telse if filter.length == 3 and _.isDate(filter[2])\n\t\t\t\t\t\t\t\t# 如果是Date类型，则filter[2]值到前端会自动转成字符串，格式：\"2018-03-29T03:43:21.787Z\"\n\t\t\t\t\t\t\t\t# 包括grid列表请求的接口在内的所有OData接口，Date类型字段都会以上述格式返回\n\t\t\t\t\t\t\t\tfilter[3] = \"DATE\"\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tif filter.length == 4 and _.isString(filter[2]) and filter[3] == \"FUNCTION\"\n\t\t\t\t\t\t\t\tfilter[2] = Creator.eval(\"(#{filter[2]})\")\n\t\t\t\t\t\t\t\tfilter.pop()\n\t\t\t\t\t\t\tif filter.length == 4 and _.isString(filter[2]) and filter[3] == \"DATE\"\n\t\t\t\t\t\t\t\tfilter[2] = new Date(filter[2])\n\t\t\t\t\t\t\t\tfilter.pop()\n\t\t\t\t\telse if _.isObject(filter)\n\t\t\t\t\t\tif Meteor.isServer\n\t\t\t\t\t\t\tif _.isFunction(filter?.value)\n\t\t\t\t\t\t\t\tfilter._value = filter.value.toString()\n\t\t\t\t\t\t\telse if _.isDate(filter?.value)\n\t\t\t\t\t\t\t\tfilter._is_date = true\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tif _.isString(filter?._value)\n\t\t\t\t\t\t\t\tfilter.value = Creator.eval(\"(#{filter._value})\")\n\t\t\t\t\t\t\telse if filter._is_date == true\n\t\t\t\t\t\t\t\tfilter.value = new Date(filter.value)\n\n\t\tif Meteor.isServer\n\t\t\tif object.form && !_.isString(object.form)\n\t\t\t\tobject.form = JSON.stringify object.form, (key, val)->\n\t\t\t\t\tif _.isFunction(val)\n\t\t\t\t\t\treturn val + '';\n\t\t\t\t\telse\n\t\t\t\t\t\treturn val;\n\t\telse if Meteor.isClient\n\t\t\tif object.form\n\t\t\t\tobject.form = JSON.parse object.form, (key, val)->\n\t\t\t\t\tif _.isString(val) && val.startsWith('function')\n\t\t\t\t\t\treturn Creator.eval(\"(#{val})\")\n\t\t\t\t\telse\n\t\t\t\t\t\treturn val;\n\n\t\tif Meteor.isClient\n\t\t\t_.forEach object.related_lists, (relatedObjInfo)->\n\t\t\t\tif _.isObject(relatedObjInfo)\n\t\t\t\t\t_.forEach relatedObjInfo, (val, key)->\n\t\t\t\t\t\tif key == 'filters' && _.isString(val)\n\t\t\t\t\t\t\ttry\n\t\t\t\t\t\t\t\trelatedObjInfo[key] = Creator.eval(\"(#{val})\")\n\t\t\t\t\t\t\tcatch error\n\t\t\t\t\t\t\t\tconsole.error \"filters_code\", val\n\t\telse\n\t\t\t_.forEach object.related_lists, (relatedObjInfo)->\n\t\t\t\tif _.isObject(relatedObjInfo)\n\t\t\t\t\t_.forEach relatedObjInfo, (val, key)->\n\t\t\t\t\t\tif key == 'filters' && _.isFunction(val)\n\t\t\t\t\t\t\trelatedObjInfo[key] = val.toString()\n\n\t\tif Meteor.isClient\n\t\t\t_.forEach object.relatedList, (relatedObjInfo)->\n\t\t\t\tif _.isObject(relatedObjInfo)\n\t\t\t\t\t_.forEach relatedObjInfo, (val, key)->\n\t\t\t\t\t\tif key == 'filters' && _.isString(val)\n\t\t\t\t\t\t\ttry\n\t\t\t\t\t\t\t\trelatedObjInfo[key] = Creator.eval(\"(#{val})\")\n\t\t\t\t\t\t\tcatch error\n\t\t\t\t\t\t\t\tconsole.error \"filters_code\", val\n\t\telse\n\t\t\t_.forEach object.relatedList, (relatedObjInfo)->\n\t\t\t\tif _.isObject(relatedObjInfo)\n\t\t\t\t\t_.forEach relatedObjInfo, (val, key)->\n\t\t\t\t\t\tif key == 'filters' && _.isFunction(val)\n\t\t\t\t\t\t\trelatedObjInfo[key] = val.toString()\n\n\t\treturn object\n\n\n","var convertField, getOption;\n\ngetOption = function(option) {\n  var foo;\n  foo = option.split(\":\");\n  if (foo.length > 2) {\n    return {\n      label: foo[0],\n      value: foo[1],\n      color: foo[2]\n    };\n  } else if (foo.length > 1) {\n    return {\n      label: foo[0],\n      value: foo[1]\n    };\n  } else {\n    return {\n      label: foo[0],\n      value: foo[0]\n    };\n  }\n};\n\nconvertField = function(object_name, field_name, field, spaceId) {\n  var allOptions, code, options, picklist, picklistOptions, ref;\n  if (Meteor.isServer && spaceId && field.type === 'select') {\n    code = field.picklist || (object_name + \".\" + field_name);\n    if (code) {\n      picklist = Creator.getPicklist(code, spaceId);\n      if (picklist) {\n        options = [];\n        allOptions = [];\n        picklistOptions = Creator.getPickListOptions(picklist);\n        picklistOptions = (ref = _.sortBy(picklistOptions, 'sort_no')) != null ? ref.reverse() : void 0;\n        _.each(picklistOptions, function(item) {\n          var label, value;\n          label = item.name;\n          value = item.value || item.name;\n          allOptions.push({\n            label: label,\n            value: value,\n            enable: item.enable,\n            color: item.color\n          });\n          if (item.enable) {\n            options.push({\n              label: label,\n              value: value,\n              color: item.color\n            });\n          }\n          if (item[\"default\"]) {\n            return field.defaultValue = value;\n          }\n        });\n        if (options.length > 0) {\n          field.options = options;\n        }\n        if (allOptions.length > 0) {\n          field.allOptions = allOptions;\n        }\n      }\n    }\n  }\n  return field;\n};\n\nCreator.convertObject = function(object, spaceId) {\n  if (!object) {\n    return;\n  }\n  _.forEach(object.triggers, function(trigger, key) {\n    var _todo, _todo_from_code, _todo_from_db;\n    if ((Meteor.isServer && trigger.on === \"server\") || (Meteor.isClient && trigger.on === \"client\")) {\n      _todo_from_code = trigger != null ? trigger._todo : void 0;\n      _todo_from_db = trigger.todo;\n      if (_todo_from_code && _.isString(_todo_from_code)) {\n        trigger.todo = Creator[\"eval\"](\"(\" + _todo_from_code + \")\");\n      }\n      if (_todo_from_db && _.isString(_todo_from_db)) {\n        if (_todo_from_db.startsWith(\"function\")) {\n          trigger.todo = Creator[\"eval\"](\"(\" + _todo_from_db + \")\");\n        } else {\n          trigger.todo = Creator[\"eval\"](\"(function(userId, doc, fieldNames, modifier, options){\" + _todo_from_db + \"})\");\n        }\n      }\n    }\n    if (Meteor.isServer && trigger.on === \"client\") {\n      _todo = trigger.todo;\n      if (_todo && _.isFunction(_todo)) {\n        return trigger._todo = _todo.toString();\n      }\n    }\n  });\n  if (Meteor.isClient) {\n    _.forEach(object.fields, function(field, key) {\n      var systemBaseFields;\n      if (field.omit) {\n        field.hidden = true;\n      }\n      if (field.required && field.readonly) {\n        field.readonly = false;\n      }\n      systemBaseFields = Creator.getSystemBaseFields();\n      if (systemBaseFields.indexOf(key) > -1) {\n        return field.readonly = true;\n      }\n    });\n    _.forEach(object.actions, function(action, key) {\n      var _todo_from_code, _todo_from_db, _visible, error;\n      _todo_from_code = action != null ? action._todo : void 0;\n      _todo_from_db = action != null ? action.todo : void 0;\n      if (_todo_from_code && _.isString(_todo_from_code)) {\n        try {\n          action.todo = Creator[\"eval\"](\"(\" + _todo_from_code + \")\");\n        } catch (error1) {\n          error = error1;\n          console.error(\"todo_from_code\", _todo_from_code);\n        }\n      }\n      if (_todo_from_db && _.isString(_todo_from_db)) {\n        try {\n          if (_todo_from_db.startsWith(\"function\")) {\n            action.todo = Creator[\"eval\"](\"(\" + _todo_from_db + \")\");\n          } else {\n            if (_.isFunction(Creator.actionsByName[_todo_from_db])) {\n              action.todo = _todo_from_db;\n            } else {\n              action.todo = Creator[\"eval\"](\"(function(){\" + _todo_from_db + \"})\");\n            }\n          }\n        } catch (error1) {\n          error = error1;\n          console.error(\"todo_from_db\", _todo_from_db, error);\n        }\n      }\n      _visible = action != null ? action._visible : void 0;\n      if (_visible) {\n        try {\n          if (_.isString(_visible)) {\n            _visible = _visible.trim();\n          }\n          if (Steedos.isExpression(_visible)) {\n            return action.visible = function(object_name, record_id, record_permissions, record) {\n              var globalData;\n              globalData = Object.assign({}, Creator.USER_CONTEXT, {\n                now: new Date()\n              });\n              return Steedos.parseSingleExpression(_visible, record, \"#\", globalData);\n            };\n          } else {\n            return action.visible = Creator[\"eval\"](\"(\" + _visible + \")\");\n          }\n        } catch (error1) {\n          error = error1;\n          return console.error(\"action.visible to function error: \", error, _visible);\n        }\n      }\n    });\n  } else {\n    _.forEach(object.actions, function(action, key) {\n      var _todo, _visible;\n      _todo = action != null ? action.todo : void 0;\n      if (_todo && _.isFunction(_todo)) {\n        action._todo = _todo.toString();\n      }\n      _visible = action != null ? action.visible : void 0;\n      if (_visible && _.isFunction(_visible)) {\n        return action._visible = _visible.toString();\n      }\n    });\n  }\n  _.forEach(object.fields, function(field, key) {\n    var _options, _type, beforeOpenFunction, createFunction, defaultValue, error, filtersFunction, is_company_limited, max, min, options, optionsFunction, reference_to, regEx;\n    field = convertField(object.name, key, field, spaceId);\n    if (field.options && _.isString(field.options)) {\n      try {\n        _options = [];\n        _.forEach(field.options.split(\"\\n\"), function(option) {\n          var options;\n          if (option.indexOf(\",\")) {\n            options = option.split(\",\");\n            return _.forEach(options, function(_option) {\n              return _options.push(getOption(_option));\n            });\n          } else {\n            return _options.push(getOption(option));\n          }\n        });\n        field.options = _options;\n      } catch (error1) {\n        error = error1;\n        console.error(\"Creator.convertFieldsOptions\", field.options, error);\n      }\n    } else if (field.options && _.isArray(field.options)) {\n      try {\n        _options = [];\n        _.forEach(field.options, function(option) {\n          if (_.isString(option)) {\n            return _options.push(getOption(option));\n          } else {\n            return _options.push(option);\n          }\n        });\n        field.options = _options;\n      } catch (error1) {\n        error = error1;\n        console.error(\"Creator.convertFieldsOptions\", field.options, error);\n      }\n    } else if (field.options && !_.isFunction(field.options) && !_.isArray(field.options) && _.isObject(field.options)) {\n      _options = [];\n      _.each(field.options, function(v, k) {\n        return _options.push({\n          label: v,\n          value: k\n        });\n      });\n      field.options = _options;\n    }\n    if (Meteor.isServer) {\n      options = field.options;\n      if (options && _.isFunction(options)) {\n        field._options = field.options.toString();\n      }\n    } else {\n      options = field._options;\n      if (options && _.isString(options)) {\n        try {\n          field.options = Creator[\"eval\"](\"(\" + options + \")\");\n        } catch (error1) {\n          error = error1;\n          console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n        }\n      }\n    }\n    if (Meteor.isServer) {\n      regEx = field.regEx;\n      if (regEx) {\n        field._regEx = field.regEx.toString();\n      }\n    } else {\n      regEx = field._regEx;\n      if (regEx) {\n        try {\n          field.regEx = Creator[\"eval\"](\"(\" + regEx + \")\");\n        } catch (error1) {\n          error = error1;\n          console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n        }\n      }\n    }\n    if (Meteor.isServer) {\n      min = field.min;\n      if (_.isFunction(min)) {\n        field._min = min.toString();\n      }\n    } else {\n      min = field._min;\n      if (_.isString(min)) {\n        try {\n          field.min = Creator[\"eval\"](\"(\" + min + \")\");\n        } catch (error1) {\n          error = error1;\n          console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n        }\n      }\n    }\n    if (Meteor.isServer) {\n      max = field.max;\n      if (_.isFunction(max)) {\n        field._max = max.toString();\n      }\n    } else {\n      max = field._max;\n      if (_.isString(max)) {\n        try {\n          field.max = Creator[\"eval\"](\"(\" + max + \")\");\n        } catch (error1) {\n          error = error1;\n          console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n        }\n      }\n    }\n    if (Meteor.isServer) {\n      if (field.autoform) {\n        _type = field.autoform.type;\n        if (_type && _.isFunction(_type) && _type !== Object && _type !== String && _type !== Number && _type !== Boolean && !_.isArray(_type)) {\n          field.autoform._type = _type.toString();\n        }\n      }\n    } else {\n      if (field.autoform) {\n        _type = field.autoform._type;\n        if (_type && _.isString(_type)) {\n          try {\n            field.autoform.type = Creator[\"eval\"](\"(\" + _type + \")\");\n          } catch (error1) {\n            error = error1;\n            console.error(\"convert field -> type error\", field, error);\n          }\n        }\n      }\n    }\n    if (Meteor.isServer) {\n      optionsFunction = field.optionsFunction;\n      reference_to = field.reference_to;\n      createFunction = field.createFunction;\n      beforeOpenFunction = field.beforeOpenFunction;\n      filtersFunction = field.filtersFunction;\n      if (optionsFunction && _.isFunction(optionsFunction)) {\n        field._optionsFunction = optionsFunction.toString();\n      }\n      if (reference_to && _.isFunction(reference_to)) {\n        field._reference_to = reference_to.toString();\n      }\n      if (createFunction && _.isFunction(createFunction)) {\n        field._createFunction = createFunction.toString();\n      }\n      if (beforeOpenFunction && _.isFunction(beforeOpenFunction)) {\n        field._beforeOpenFunction = beforeOpenFunction.toString();\n      }\n      if (filtersFunction && _.isFunction(filtersFunction)) {\n        field._filtersFunction = filtersFunction.toString();\n      }\n    } else {\n      optionsFunction = field._optionsFunction || field.optionsFunction;\n      reference_to = field._reference_to;\n      createFunction = field._createFunction;\n      beforeOpenFunction = field._beforeOpenFunction;\n      filtersFunction = field._filtersFunction || field.filtersFunction;\n      if (optionsFunction && _.isString(optionsFunction)) {\n        field.optionsFunction = Creator[\"eval\"](\"(\" + optionsFunction + \")\");\n      }\n      if (reference_to && _.isString(reference_to)) {\n        field.reference_to = Creator[\"eval\"](\"(\" + reference_to + \")\");\n      }\n      if (createFunction && _.isString(createFunction)) {\n        field.createFunction = Creator[\"eval\"](\"(\" + createFunction + \")\");\n      }\n      if (beforeOpenFunction && _.isString(beforeOpenFunction)) {\n        field.beforeOpenFunction = Creator[\"eval\"](\"(\" + beforeOpenFunction + \")\");\n      }\n      if (filtersFunction && _.isString(filtersFunction)) {\n        field.filtersFunction = Creator[\"eval\"](\"(\" + filtersFunction + \")\");\n      }\n    }\n    if (Meteor.isServer) {\n      defaultValue = field.defaultValue;\n      if (defaultValue && _.isFunction(defaultValue)) {\n        field._defaultValue = field.defaultValue.toString();\n      }\n    } else {\n      defaultValue = field._defaultValue;\n      if (!defaultValue && _.isString(field.defaultValue) && field.defaultValue.startsWith(\"function\")) {\n        defaultValue = field.defaultValue;\n      }\n      if (defaultValue && _.isString(defaultValue)) {\n        try {\n          field.defaultValue = Creator[\"eval\"](\"(\" + defaultValue + \")\");\n        } catch (error1) {\n          error = error1;\n          console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n        }\n      }\n    }\n    if (Meteor.isServer) {\n      is_company_limited = field.is_company_limited;\n      if (is_company_limited && _.isFunction(is_company_limited)) {\n        return field._is_company_limited = field.is_company_limited.toString();\n      }\n    } else {\n      is_company_limited = field._is_company_limited;\n      if (is_company_limited && _.isString(is_company_limited)) {\n        try {\n          return field.is_company_limited = Creator[\"eval\"](\"(\" + is_company_limited + \")\");\n        } catch (error1) {\n          error = error1;\n          return console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n        }\n      }\n    }\n  });\n  _.forEach(object.list_views, function(list_view, key) {\n\n    /*\n    \t\t\t视图过虑器需要支持function，后台转成字符串，前台eval成函数\n    \t\t\t让过虑器支持两种function方式：\n    \t\t\t1. 整个filters为function:\n    \t\t\t如：\n    \t\t\tfilters: ()->\n    \t\t\t\treturn [[[\"object_name\",\"=\",\"project_issues\"],'or',[\"object_name\",\"=\",\"tasks\"]]]\n    \t\t\t2. filters内的filter.value为function\n    \t\t\t如：\n    \t\t\tfilters: [[\"object_name\", \"=\", ()->\n    \t\t\t\treturn \"project_issues\"\n    \t\t\t]]\n    \t\t\t或\n    \t\t\tfilters: [{\n    \t\t\t\t\"field\": \"object_name\"\n    \t\t\t\t\"operation\": \"=\"\n    \t\t\t\t\"value\": ()->\n    \t\t\t\t\treturn \"project_issues\"\n    \t\t\t}]\n     */\n    if (_.isFunction(list_view.filters)) {\n      if (Meteor.isServer) {\n        return list_view._filters = list_view.filters.toString();\n      }\n    } else if (_.isString(list_view._filters)) {\n      if (Meteor.isClient) {\n        return list_view.filters = Creator[\"eval\"](\"(\" + list_view._filters + \")\");\n      }\n    } else {\n      return _.forEach(list_view.filters, function(filter, _index) {\n        if (_.isArray(filter)) {\n          if (Meteor.isServer) {\n            if (filter.length === 3 && _.isFunction(filter[2])) {\n              filter[2] = filter[2].toString();\n              return filter[3] = \"FUNCTION\";\n            } else if (filter.length === 3 && _.isDate(filter[2])) {\n              return filter[3] = \"DATE\";\n            }\n          } else {\n            if (filter.length === 4 && _.isString(filter[2]) && filter[3] === \"FUNCTION\") {\n              filter[2] = Creator[\"eval\"](\"(\" + filter[2] + \")\");\n              filter.pop();\n            }\n            if (filter.length === 4 && _.isString(filter[2]) && filter[3] === \"DATE\") {\n              filter[2] = new Date(filter[2]);\n              return filter.pop();\n            }\n          }\n        } else if (_.isObject(filter)) {\n          if (Meteor.isServer) {\n            if (_.isFunction(filter != null ? filter.value : void 0)) {\n              return filter._value = filter.value.toString();\n            } else if (_.isDate(filter != null ? filter.value : void 0)) {\n              return filter._is_date = true;\n            }\n          } else {\n            if (_.isString(filter != null ? filter._value : void 0)) {\n              return filter.value = Creator[\"eval\"](\"(\" + filter._value + \")\");\n            } else if (filter._is_date === true) {\n              return filter.value = new Date(filter.value);\n            }\n          }\n        }\n      });\n    }\n  });\n  if (Meteor.isServer) {\n    if (object.form && !_.isString(object.form)) {\n      object.form = JSON.stringify(object.form, function(key, val) {\n        if (_.isFunction(val)) {\n          return val + '';\n        } else {\n          return val;\n        }\n      });\n    }\n  } else if (Meteor.isClient) {\n    if (object.form) {\n      object.form = JSON.parse(object.form, function(key, val) {\n        if (_.isString(val) && val.startsWith('function')) {\n          return Creator[\"eval\"](\"(\" + val + \")\");\n        } else {\n          return val;\n        }\n      });\n    }\n  }\n  if (Meteor.isClient) {\n    _.forEach(object.related_lists, function(relatedObjInfo) {\n      if (_.isObject(relatedObjInfo)) {\n        return _.forEach(relatedObjInfo, function(val, key) {\n          var error;\n          if (key === 'filters' && _.isString(val)) {\n            try {\n              return relatedObjInfo[key] = Creator[\"eval\"](\"(\" + val + \")\");\n            } catch (error1) {\n              error = error1;\n              return console.error(\"filters_code\", val);\n            }\n          }\n        });\n      }\n    });\n  } else {\n    _.forEach(object.related_lists, function(relatedObjInfo) {\n      if (_.isObject(relatedObjInfo)) {\n        return _.forEach(relatedObjInfo, function(val, key) {\n          if (key === 'filters' && _.isFunction(val)) {\n            return relatedObjInfo[key] = val.toString();\n          }\n        });\n      }\n    });\n  }\n  if (Meteor.isClient) {\n    _.forEach(object.relatedList, function(relatedObjInfo) {\n      if (_.isObject(relatedObjInfo)) {\n        return _.forEach(relatedObjInfo, function(val, key) {\n          var error;\n          if (key === 'filters' && _.isString(val)) {\n            try {\n              return relatedObjInfo[key] = Creator[\"eval\"](\"(\" + val + \")\");\n            } catch (error1) {\n              error = error1;\n              return console.error(\"filters_code\", val);\n            }\n          }\n        });\n      }\n    });\n  } else {\n    _.forEach(object.relatedList, function(relatedObjInfo) {\n      if (_.isObject(relatedObjInfo)) {\n        return _.forEach(relatedObjInfo, function(val, key) {\n          if (key === 'filters' && _.isFunction(val)) {\n            return relatedObjInfo[key] = val.toString();\n          }\n        });\n      }\n    });\n  }\n  return object;\n};\n","Creator.Formular = {}\n\nCreator.Formular.PREFIX = \"_VALUES\"\n\nCreator.Formular._prependPrefixForFormula = (prefix,fieldVariable)->\n\treg = /(\\{[^{}]*\\})/g;\n\n\trev = fieldVariable.replace reg, (m, $1)->\n\t\treturn prefix + $1.replace(/\\{\\s*/,\"[\\\"\").replace(/\\s*\\}/,\"\\\"]\").replace(/\\s*\\.\\s*/g,\"\\\"][\\\"\");\n\n\treturn rev\n\nCreator.Formular.checkFormula = (formula_str)->\n\tif _.isString(formula_str) && formula_str.indexOf(\"{\") > -1 && formula_str.indexOf(\"}\") > -1\n\t\treturn true\n\treturn false\n\nCreator.Formular.run = (formula_str, _CONTEXT, options)->\n\tif formula_str && _.isString(formula_str)\n\n\t\tif !_.isBoolean(options?.extend)\n\t\t\textend = true\n\n\t\t_VALUES = {}\n\t\t_VALUES = _.extend(_VALUES, _CONTEXT)\n\t\tif extend\n\t\t\t_VALUES = _.extend(_VALUES, Creator.getUserContext(options?.userId, options?.spaceId))\n\t\tformula_str = Creator.Formular._prependPrefixForFormula(\"this\", formula_str)\n\n\t\ttry\n\t\t\tdata = Creator.evalInContext(formula_str, _VALUES)   # 此处不能用window.eval ，会导致变量作用域异常\n\t\t\treturn data\n\t\tcatch e\n\t\t\tconsole.error(\"Creator.Formular.run: #{formula_str}\", e)\n\t\t\tif Meteor.isClient\n\t\t\t\ttoastr?.error(\"公式执行出错了，请检查公式配置是否正确！\")\n\t\t\tthrow new Meteor.Error 500, \"Creator.Formular.run: #{formula_str}#{e}\"\n\n\treturn formula_str\n","Creator.Formular = {};\n\nCreator.Formular.PREFIX = \"_VALUES\";\n\nCreator.Formular._prependPrefixForFormula = function(prefix, fieldVariable) {\n  var reg, rev;\n  reg = /(\\{[^{}]*\\})/g;\n  rev = fieldVariable.replace(reg, function(m, $1) {\n    return prefix + $1.replace(/\\{\\s*/, \"[\\\"\").replace(/\\s*\\}/, \"\\\"]\").replace(/\\s*\\.\\s*/g, \"\\\"][\\\"\");\n  });\n  return rev;\n};\n\nCreator.Formular.checkFormula = function(formula_str) {\n  if (_.isString(formula_str) && formula_str.indexOf(\"{\") > -1 && formula_str.indexOf(\"}\") > -1) {\n    return true;\n  }\n  return false;\n};\n\nCreator.Formular.run = function(formula_str, _CONTEXT, options) {\n  var _VALUES, data, e, extend;\n  if (formula_str && _.isString(formula_str)) {\n    if (!_.isBoolean(options != null ? options.extend : void 0)) {\n      extend = true;\n    }\n    _VALUES = {};\n    _VALUES = _.extend(_VALUES, _CONTEXT);\n    if (extend) {\n      _VALUES = _.extend(_VALUES, Creator.getUserContext(options != null ? options.userId : void 0, options != null ? options.spaceId : void 0));\n    }\n    formula_str = Creator.Formular._prependPrefixForFormula(\"this\", formula_str);\n    try {\n      data = Creator.evalInContext(formula_str, _VALUES);\n      return data;\n    } catch (error) {\n      e = error;\n      console.error(\"Creator.Formular.run: \" + formula_str, e);\n      if (Meteor.isClient) {\n        if (typeof toastr !== \"undefined\" && toastr !== null) {\n          toastr.error(\"公式执行出错了，请检查公式配置是否正确！\");\n        }\n      }\n      throw new Meteor.Error(500, \"Creator.Formular.run: \" + formula_str + e);\n    }\n  }\n  return formula_str;\n};\n","clone = require('clone');\nCreator.objectsByName = {}   # 此对象只能在确保所有Object初始化完成后调用， 否则获取到的object不全\n\nCreator.formatObjectName = (object_name)->\n\tif object_name.startsWith('cfs.files.')\n\t\tobject_name = object_name.replace(new RegExp('\\\\.', 'g'), '_')\n\treturn object_name\n\nCreator.Object = (options)->\n\t_baseObject = Creator.baseObject\n\tif Meteor.isClient\n\t\t_baseObject = {actions: Creator.baseObject.actions , fields: {}, triggers: {}, permission_set: {}}\n\tself = this\n\tif (!options.name)\n\t\tconsole.error(options)\n\t\tthrow new Error('Creator.Object options must specify name');\n\n\tself._id = options._id || options.name\n\tself.space = options.space\n\tself.name = options.name\n\tself.label = options.label\n\tself.icon = options.icon\n\tself.description = options.description\n\tself.is_view = options.is_view\n\tself.form = options.form\n\tself.relatedList = options.relatedList\n\tself.related_lists = options.related_lists\n\tself.hasImportTemplates = options.hasImportTemplates\n\tself.version = options.version || 1.0\n\tif !_.isBoolean(options.is_enable)  || options.is_enable == true\n\t\tself.is_enable = true\n\telse\n\t\tself.is_enable = false\n\tif Meteor.isClient\n\t\tif _.has(options, 'allow_customActions')\n\t\t\tself.allow_customActions = options.allow_customActions\n\t\tif _.has(options, 'exclude_actions')\n\t\t\tself.exclude_actions = options.exclude_actions\n\t\tif _.has(options, 'allow_relatedList')\n\t\t\tself.allow_relatedList = options.allow_relatedList\n\tself.enable_search = options.enable_search\n\tself.enable_files = options.enable_files\n\tself.enable_tasks = options.enable_tasks\n\tself.enable_notes = options.enable_notes\n\tself.enable_audit = options.enable_audit\n\tself.enable_events = options.enable_events\n\tif options.paging\n\t\tself.paging = options.paging\n\tself.hidden = options.hidden\n\tself.enable_api = (options.enable_api == undefined) or options.enable_api\n\tself.custom = options.custom\n\tself.enable_share = options.enable_share\n\tself.enable_instances = options.enable_instances\n\tself.enable_process = options.enable_process\n\tif Meteor.isClient\n\t\tif Creator.isCloudAdminSpace(Session.get(\"spaceId\"))\n\t\t\tself.enable_tree = false\n\t\telse\n\t\t\tself.enable_tree = options.enable_tree\n\t\t\tself.sidebar = _.clone(options.sidebar)\n\telse\n\t\tself.sidebar = _.clone(options.sidebar)\n\t\tself.enable_tree = options.enable_tree\n\tself.open_window = options.open_window\n\tself.filter_company = options.filter_company\n\tself.calendar = _.clone(options.calendar)\n\tself.enable_chatter = options.enable_chatter\n\tself.enable_trash = options.enable_trash\n\tself.enable_space_global = options.enable_space_global\n\tself.enable_approvals = options.enable_approvals\n\tself.enable_follow = options.enable_follow\n\tself.enable_workflow = options.enable_workflow\n\tself.enable_inline_edit = options.enable_inline_edit\n\tself.details = options.details\n\tself.masters = options.masters\n\tself.lookup_details = options.lookup_details\n\tif _.has(options, 'in_development')\n\t\tself.in_development = options.in_development\n\tself.idFieldName = '_id'\n\tif options.database_name\n\t\tself.database_name = options.database_name\n\tif (!options.fields)\n\t\tconsole.error(options)\n\t\tthrow new Error('Creator.Object options must specify fields');\n\n\tself.fields = clone(options.fields)\n\n\t_.each self.fields, (field, field_name)->\n\t\tif field.is_name\n\t\t\tself.NAME_FIELD_KEY = field_name\n\t\telse if field_name == 'name' && !self.NAME_FIELD_KEY\n\t\t\tself.NAME_FIELD_KEY = field_name\n\t\tif field.primary\n\t\t\tself.idFieldName = field_name\n\t\tif Meteor.isClient\n\t\t\tif Creator.isCloudAdminSpace(Session.get(\"spaceId\"))\n\t\t\t\tif field_name == 'space'\n\t\t\t\t\tfield.filterable = true\n\t\t\t\t\tfield.hidden = false\n\n\tif !options.database_name || options.database_name == 'meteor-mongo'\n\t\t_.each _baseObject.fields, (field, field_name)->\n\t\t\tif !self.fields[field_name]\n\t\t\t\tself.fields[field_name] = {}\n\t\t\tself.fields[field_name] = _.extend(_.clone(field), self.fields[field_name])\n\n\t_.each self.fields, (field, field_name)->\n\t\tif field.type == 'autonumber'\n\t\t\tfield.readonly = true\n\t\telse if field.type == 'formula'\n\t\t\tfield.readonly = true\n\t\telse if field.type == 'summary'\n\t\t\tfield.readonly = true\n\n\tself.list_views = {}\n\tdefaultView = Creator.getObjectDefaultView(self.name)\n\t_.each options.list_views, (item, item_name)->\n\t\toitem = Creator.convertListView(defaultView, item, item_name)\n\t\tself.list_views[item_name] = oitem\n\n\tself.triggers = _.clone(_baseObject.triggers)\n\t_.each options.triggers, (item, item_name)->\n\t\tif !self.triggers[item_name]\n\t\t\tself.triggers[item_name] = {}\n\t\tself.triggers[item_name].name = item_name\n\t\tself.triggers[item_name] = _.extend(_.clone(self.triggers[item_name]), item)\n\n\tself.actions = _.clone(_baseObject.actions)\n\t_.each options.actions, (item, item_name)->\n\t\tif !self.actions[item_name]\n\t\t\tself.actions[item_name] = {}\n\t\tcopyItem = _.clone(self.actions[item_name])\n\t\tdelete self.actions[item_name] #先删除相关属性再重建才能保证后续重复定义的属性顺序生效\n\t\tself.actions[item_name] = _.extend(copyItem, item)\n\t\tself.actions[item_name].object_name = self.name\n\n\t_.each self.actions, (item, item_name)->\n\t\titem.name = item_name\n\n\tself.related_objects = Creator.getObjectRelateds(self.name)\n\n\t# 让所有object默认有所有list_views/actions/related_objects/readable_fields/editable_fields完整权限，该权限可能被数据库中设置的admin/user权限覆盖\n\tself.permission_set = _.clone(_baseObject.permission_set)\n\t# defaultListViews = _.keys(self.list_views)\n\t# defaultActions = _.keys(self.actions)\n\t# defaultRelatedObjects = _.pluck(self.related_objects,\"object_name\")\n\t# defaultReadableFields = []\n\t# defaultEditableFields = []\n\t# _.each self.fields, (field, field_name)->\n\t# \tif !(field.hidden)    #231 omit字段支持在非编辑页面查看, 因此删除了此处对omit的判断\n\t# \t\tdefaultReadableFields.push field_name\n\t# \t\tif !field.readonly\n\t# \t\t\tdefaultEditableFields.push field_name\n\n\t# _.each self.permission_set, (item, item_name)->\n\t# \tif item_name == \"none\"\n\t# \t\treturn\n\t# \tif self.list_views\n\t# \t\tself.permission_set[item_name].list_views = defaultListViews\n\t# \tif self.actions\n\t# \t\tself.permission_set[item_name].actions = defaultActions\n\t# \tif self.related_objects\n\t# \t\tself.permission_set[item_name].related_objects = defaultRelatedObjects\n\t# \tif self.fields\n\t# \t\tself.permission_set[item_name].readable_fields = defaultReadableFields\n\t# \t\tself.permission_set[item_name].editable_fields = defaultEditableFields\n\tunless options.permission_set\n\t\toptions.permission_set = {}\n\tif !(options.permission_set?.admin)\n\t\toptions.permission_set.admin = _.clone(self.permission_set[\"admin\"])\n\tif !(options.permission_set?.user)\n\t\toptions.permission_set.user = _.clone(self.permission_set[\"user\"])\n\t_.each options.permission_set, (item, item_name)->\n\t\tif !self.permission_set[item_name]\n\t\t\tself.permission_set[item_name] = {}\n\t\tself.permission_set[item_name] = _.extend(_.clone(self.permission_set[item_name]), item)\n\n\t# 前端根据permissions改写field相关属性，后端只要走默认属性就行，不需要改写\n\tif Meteor.isClient\n\t\tpermissions = options.permissions\n\t\tdisabled_list_views = permissions?.disabled_list_views\n\t\tif disabled_list_views?.length\n\t\t\tdefaultListViewId = options.list_views?.all?._id\n\t\t\tif defaultListViewId\n\t\t\t\t# 把视图权限配置中默认的all视图id转换成all关键字\n\t\t\t\tpermissions.disabled_list_views = _.map disabled_list_views, (list_view_item) ->\n\t\t\t\t\treturn if defaultListViewId == list_view_item then \"all\" else list_view_item\n\t\tself.permissions = new ReactiveVar(permissions)\n#\t\t_.each self.fields, (field, field_name)->\n#\t\t\tif field\n#\t\t\t\tif _.indexOf(permissions?.unreadable_fields, field_name) < 0\n#\t\t\t\t\tif field.hidden\n#\t\t\t\t\t\treturn\n#\t\t\t\t\tif _.indexOf(permissions?.uneditable_fields, field_name) > -1\n#\t\t\t\t\t\tfield.readonly = true\n#\t\t\t\t\t\tfield.disabled = true\n#\t\t\t\t\t\t# 当只读时，如果不去掉必填字段，autoform是会报错的\n#\t\t\t\t\t\tfield.required = false\n#\t\t\t\telse\n#\t\t\t\t\tfield.hidden = true\n\telse\n\t\tself.permissions = null\n\n\t_db = Creator.createCollection(options)\n\n\tCreator.Collections[_db._name] = _db\n\n\tself.db = _db\n\n\tself._collection_name = _db._name\n\n\tschema = Creator.getObjectSchema(self)\n\tself.schema = new SimpleSchema(schema)\n\tif self.name != \"users\" and self.name != \"cfs.files.filerecord\" && !self.is_view && !_.contains([\"flows\", \"forms\", \"instances\", \"organizations\", \"action_field_updates\", \"object_listviews\"], self.name)\n\t\tif Meteor.isClient\n\t\t\t_db.attachSchema(self.schema, {replace: true})\n\t\telse\n\t\t\t_db.attachSchema(self.schema, {replace: true})\n\tif self.name == \"users\"\n\t\t_db._simpleSchema = self.schema\n\n\tif _.contains([\"flows\", \"forms\", \"instances\", \"organizations\"], self.name)\n\t\tif Meteor.isClient\n\t\t\t_db.attachSchema(self.schema, {replace: true})\n\n\tCreator.objectsByName[self._collection_name] = self\n\n\treturn self\n\n# Creator.Object.prototype.i18n = ()->\n# \t# set object label\n# \tself = this\n\n# \tkey = self.name\n# \tif t(key) == key\n# \t\tif !self.label\n# \t\t\tself.label = self.name\n# \telse\n# \t\tself.label = t(key)\n\n# \t# set field labels\n# \t_.each self.fields, (field, field_name)->\n# \t\tfkey = self.name + \"_\" + field_name\n# \t\tif t(fkey) == fkey\n# \t\t\tif !field.label\n# \t\t\t\tfield.label = field_name\n# \t\telse\n# \t\t\tfield.label = t(fkey)\n# \t\tself.schema?._schema?[field_name]?.label = field.label\n\n\n# \t# set listview labels\n# \t_.each self.list_views, (item, item_name)->\n# \t\ti18n_key = self.name + \"_listview_\" + item_name\n# \t\tif t(i18n_key) == i18n_key\n# \t\t\tif !item.label\n# \t\t\t\titem.label = item_name\n# \t\telse\n# \t\t\titem.label = t(i18n_key)\n\n\nCreator.getObjectODataRouterPrefix = (object)->\n\treturn \"/api/odata/v4\"\n\t# if object\n\t# \tif !object.database_name || object.database_name == 'meteor-mongo'\n\t# \t\treturn \"/api/odata/v4\"\n\t# \telse\n\t# \t\treturn \"/api/odata/#{object.database_name}\"\n\n# if Meteor.isClient\n\n# \tMeteor.startup ->\n# \t\tTracker.autorun ->\n# \t\t\tif Session.get(\"steedos-locale\") && Creator.bootstrapLoaded?.get()\n# \t\t\t\t_.each Creator.objectsByName, (object, object_name)->\n# \t\t\t\t\tobject.i18n()\n\nMeteor.startup ->\n\tif !Creator.bootstrapLoaded && Creator.Objects\n\t\t_.each Creator.Objects, (object)->\n\t\t\tnew Creator.Object(object)\n\n","var clone;\n\nclone = require('clone');\n\nCreator.objectsByName = {};\n\nCreator.formatObjectName = function(object_name) {\n  if (object_name.startsWith('cfs.files.')) {\n    object_name = object_name.replace(new RegExp('\\\\.', 'g'), '_');\n  }\n  return object_name;\n};\n\nCreator.Object = function(options) {\n  var _baseObject, _db, defaultListViewId, defaultView, disabled_list_views, permissions, ref, ref1, ref2, ref3, schema, self;\n  _baseObject = Creator.baseObject;\n  if (Meteor.isClient) {\n    _baseObject = {\n      actions: Creator.baseObject.actions,\n      fields: {},\n      triggers: {},\n      permission_set: {}\n    };\n  }\n  self = this;\n  if (!options.name) {\n    console.error(options);\n    throw new Error('Creator.Object options must specify name');\n  }\n  self._id = options._id || options.name;\n  self.space = options.space;\n  self.name = options.name;\n  self.label = options.label;\n  self.icon = options.icon;\n  self.description = options.description;\n  self.is_view = options.is_view;\n  self.form = options.form;\n  self.relatedList = options.relatedList;\n  self.related_lists = options.related_lists;\n  self.hasImportTemplates = options.hasImportTemplates;\n  self.version = options.version || 1.0;\n  if (!_.isBoolean(options.is_enable) || options.is_enable === true) {\n    self.is_enable = true;\n  } else {\n    self.is_enable = false;\n  }\n  if (Meteor.isClient) {\n    if (_.has(options, 'allow_customActions')) {\n      self.allow_customActions = options.allow_customActions;\n    }\n    if (_.has(options, 'exclude_actions')) {\n      self.exclude_actions = options.exclude_actions;\n    }\n    if (_.has(options, 'allow_relatedList')) {\n      self.allow_relatedList = options.allow_relatedList;\n    }\n  }\n  self.enable_search = options.enable_search;\n  self.enable_files = options.enable_files;\n  self.enable_tasks = options.enable_tasks;\n  self.enable_notes = options.enable_notes;\n  self.enable_audit = options.enable_audit;\n  self.enable_events = options.enable_events;\n  if (options.paging) {\n    self.paging = options.paging;\n  }\n  self.hidden = options.hidden;\n  self.enable_api = (options.enable_api === void 0) || options.enable_api;\n  self.custom = options.custom;\n  self.enable_share = options.enable_share;\n  self.enable_instances = options.enable_instances;\n  self.enable_process = options.enable_process;\n  if (Meteor.isClient) {\n    if (Creator.isCloudAdminSpace(Session.get(\"spaceId\"))) {\n      self.enable_tree = false;\n    } else {\n      self.enable_tree = options.enable_tree;\n      self.sidebar = _.clone(options.sidebar);\n    }\n  } else {\n    self.sidebar = _.clone(options.sidebar);\n    self.enable_tree = options.enable_tree;\n  }\n  self.open_window = options.open_window;\n  self.filter_company = options.filter_company;\n  self.calendar = _.clone(options.calendar);\n  self.enable_chatter = options.enable_chatter;\n  self.enable_trash = options.enable_trash;\n  self.enable_space_global = options.enable_space_global;\n  self.enable_approvals = options.enable_approvals;\n  self.enable_follow = options.enable_follow;\n  self.enable_workflow = options.enable_workflow;\n  self.enable_inline_edit = options.enable_inline_edit;\n  self.details = options.details;\n  self.masters = options.masters;\n  self.lookup_details = options.lookup_details;\n  if (_.has(options, 'in_development')) {\n    self.in_development = options.in_development;\n  }\n  self.idFieldName = '_id';\n  if (options.database_name) {\n    self.database_name = options.database_name;\n  }\n  if (!options.fields) {\n    console.error(options);\n    throw new Error('Creator.Object options must specify fields');\n  }\n  self.fields = clone(options.fields);\n  _.each(self.fields, function(field, field_name) {\n    if (field.is_name) {\n      self.NAME_FIELD_KEY = field_name;\n    } else if (field_name === 'name' && !self.NAME_FIELD_KEY) {\n      self.NAME_FIELD_KEY = field_name;\n    }\n    if (field.primary) {\n      self.idFieldName = field_name;\n    }\n    if (Meteor.isClient) {\n      if (Creator.isCloudAdminSpace(Session.get(\"spaceId\"))) {\n        if (field_name === 'space') {\n          field.filterable = true;\n          return field.hidden = false;\n        }\n      }\n    }\n  });\n  if (!options.database_name || options.database_name === 'meteor-mongo') {\n    _.each(_baseObject.fields, function(field, field_name) {\n      if (!self.fields[field_name]) {\n        self.fields[field_name] = {};\n      }\n      return self.fields[field_name] = _.extend(_.clone(field), self.fields[field_name]);\n    });\n  }\n  _.each(self.fields, function(field, field_name) {\n    if (field.type === 'autonumber') {\n      return field.readonly = true;\n    } else if (field.type === 'formula') {\n      return field.readonly = true;\n    } else if (field.type === 'summary') {\n      return field.readonly = true;\n    }\n  });\n  self.list_views = {};\n  defaultView = Creator.getObjectDefaultView(self.name);\n  _.each(options.list_views, function(item, item_name) {\n    var oitem;\n    oitem = Creator.convertListView(defaultView, item, item_name);\n    return self.list_views[item_name] = oitem;\n  });\n  self.triggers = _.clone(_baseObject.triggers);\n  _.each(options.triggers, function(item, item_name) {\n    if (!self.triggers[item_name]) {\n      self.triggers[item_name] = {};\n    }\n    self.triggers[item_name].name = item_name;\n    return self.triggers[item_name] = _.extend(_.clone(self.triggers[item_name]), item);\n  });\n  self.actions = _.clone(_baseObject.actions);\n  _.each(options.actions, function(item, item_name) {\n    var copyItem;\n    if (!self.actions[item_name]) {\n      self.actions[item_name] = {};\n    }\n    copyItem = _.clone(self.actions[item_name]);\n    delete self.actions[item_name];\n    self.actions[item_name] = _.extend(copyItem, item);\n    return self.actions[item_name].object_name = self.name;\n  });\n  _.each(self.actions, function(item, item_name) {\n    return item.name = item_name;\n  });\n  self.related_objects = Creator.getObjectRelateds(self.name);\n  self.permission_set = _.clone(_baseObject.permission_set);\n  if (!options.permission_set) {\n    options.permission_set = {};\n  }\n  if (!((ref = options.permission_set) != null ? ref.admin : void 0)) {\n    options.permission_set.admin = _.clone(self.permission_set[\"admin\"]);\n  }\n  if (!((ref1 = options.permission_set) != null ? ref1.user : void 0)) {\n    options.permission_set.user = _.clone(self.permission_set[\"user\"]);\n  }\n  _.each(options.permission_set, function(item, item_name) {\n    if (!self.permission_set[item_name]) {\n      self.permission_set[item_name] = {};\n    }\n    return self.permission_set[item_name] = _.extend(_.clone(self.permission_set[item_name]), item);\n  });\n  if (Meteor.isClient) {\n    permissions = options.permissions;\n    disabled_list_views = permissions != null ? permissions.disabled_list_views : void 0;\n    if (disabled_list_views != null ? disabled_list_views.length : void 0) {\n      defaultListViewId = (ref2 = options.list_views) != null ? (ref3 = ref2.all) != null ? ref3._id : void 0 : void 0;\n      if (defaultListViewId) {\n        permissions.disabled_list_views = _.map(disabled_list_views, function(list_view_item) {\n          if (defaultListViewId === list_view_item) {\n            return \"all\";\n          } else {\n            return list_view_item;\n          }\n        });\n      }\n    }\n    self.permissions = new ReactiveVar(permissions);\n  } else {\n    self.permissions = null;\n  }\n  _db = Creator.createCollection(options);\n  Creator.Collections[_db._name] = _db;\n  self.db = _db;\n  self._collection_name = _db._name;\n  schema = Creator.getObjectSchema(self);\n  self.schema = new SimpleSchema(schema);\n  if (self.name !== \"users\" && self.name !== \"cfs.files.filerecord\" && !self.is_view && !_.contains([\"flows\", \"forms\", \"instances\", \"organizations\", \"action_field_updates\", \"object_listviews\"], self.name)) {\n    if (Meteor.isClient) {\n      _db.attachSchema(self.schema, {\n        replace: true\n      });\n    } else {\n      _db.attachSchema(self.schema, {\n        replace: true\n      });\n    }\n  }\n  if (self.name === \"users\") {\n    _db._simpleSchema = self.schema;\n  }\n  if (_.contains([\"flows\", \"forms\", \"instances\", \"organizations\"], self.name)) {\n    if (Meteor.isClient) {\n      _db.attachSchema(self.schema, {\n        replace: true\n      });\n    }\n  }\n  Creator.objectsByName[self._collection_name] = self;\n  return self;\n};\n\nCreator.getObjectODataRouterPrefix = function(object) {\n  return \"/api/odata/v4\";\n};\n\nMeteor.startup(function() {\n  if (!Creator.bootstrapLoaded && Creator.Objects) {\n    return _.each(Creator.Objects, function(object) {\n      return new Creator.Object(object);\n    });\n  }\n});\n","Creator.getSelectOptions = (fieldSchema) ->\n\toptions = fieldSchema.options\n\tunless options\n\t\treturn\n\tdata_type = fieldSchema.data_type\n\tif !_.isFunction(options) and data_type and data_type != 'text'\n\t\t# 零代码界面配置options选项值只支持字符串，所以当data_type为数值或boolean时，只能强行把选项值先转换为对应的类型\n\t\toptions.forEach (optionItem) ->\n\t\t\tif typeof optionItem.value != 'string'\n\t\t\t\treturn\n\t\t\tif [\n\t\t\t\t'number'\n\t\t\t\t'currency'\n\t\t\t\t'percent'\n\t\t\t].indexOf(data_type) > -1\n\t\t\t\toptionItem.value = Number(optionItem.value)\n\t\t\telse if data_type == 'boolean'\n\t\t\t\t# 只有为true才为真\n\t\t\t\toptionItem.value = optionItem.value == 'true'\n\treturn options\n\nCreator.getObjectSchema = (obj) ->\n\tunless obj\n\t\treturn\n\tschema = {}\n\n\tfieldsArr = []\n\n\t_.each obj.fields , (field, field_name)->\n\t\tif !_.has(field, \"name\")\n\t\t\tfield.name = field_name\n\t\tfieldsArr.push field\n\n\t_.each _.sortBy(fieldsArr, \"sort_no\"), (field)->\n\n\t\tfield_name = field.name\n\n\t\tfs = {}\n\t\tif field.regEx\n\t\t\tfs.regEx = field.regEx\n\t\tfs.autoform = {}\n\t\tfs.autoform.multiple = field.multiple\n\t\tfs.autoform.reference_to = field.reference_to\n\n\t\tautoform_type = field.autoform?.type\n\n\t\tif field.type == \"text\" or field.type == \"phone\"\n\t\t\tfs.type = String\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tfs.autoform.type = \"tags\"\n\t\telse if field.type == \"[text]\" or field.type == \"[phone]\"\n\t\t\tfs.type = [String]\n\t\t\tfs.autoform.type = \"tags\"\n\t\telse if field.type == 'code'\n\t\t\tfs.type = String\n\t\t\tfs.autoform.type = \"widearea\"\n\t\t\tfs.autoform.rows = field.rows || 12\n\t\t\tif field.language\n\t\t\t\tfs.autoform.language = field.language\n\t\telse if field.type == \"textarea\"\n\t\t\tfs.type = String\n\t\t\tfs.autoform.type = \"widearea\"\n\t\t\tfs.autoform.rows = field.rows || 2\n\t\telse if field.type == \"password\"\n\t\t\tfs.type = String\n\t\t\tfs.autoform.type = \"password\"\n\t\telse if field.type == \"date\"\n\t\t\tfs.type = Date\n\t\t\tif Meteor.isClient\n\t\t\t\tif Steedos.isMobile() || Steedos.isPad()\n\t\t\t\t\tif Steedos.isiOS()\n\t\t\t\t\t\t# Fix ios 14, 手机客户端待审核文件日期控件显示故障 #991，ios统一用PC端一样的js控件\n\t\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\t\t\ttimezoneId: \"utc\"\n\t\t\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\t\t\ttype: \"date\"\n\t\t\t\t\t\t\t\tdisplayFormat: \"yyyy-MM-dd\"\n\t\t\t\t\t\t\t\tpickerType: \"rollers\"\n\t\t\t\t\telse\n\t\t\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\t\ttype: \"steedos-date-mobile\"\n\t\t\t\t\t\t\tdateMobileOptions:\n\t\t\t\t\t\t\t\ttype: \"date\"\n\t\t\t\telse\n\t\t\t\t\tfs.autoform.outFormat = 'yyyy-MM-dd';\n\t\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\t\ttimezoneId: \"utc\"\n\t\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\t\ttype: \"date\"\n\t\t\t\t\t\t\tdisplayFormat: \"yyyy-MM-dd\"\n\t\telse if field.type == \"time\"\n\t\t\tfs.type = Date\n\t\t\tif Meteor.isClient\n\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\ttimezoneId: \"utc\"\n\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\ttype: \"time\"\n\t\t\t\t\t\tdisplayFormat: \"HH:mm\"\n\t\telse if field.type == \"datetime\"\n\t\t\tfs.type = Date\n\t\t\tif Meteor.isClient\n\t\t\t\tif Steedos.isMobile() || Steedos.isPad()\n\t\t\t\t\tif Steedos.isiOS()\n\t\t\t\t\t\t# Fix ios 14, 手机客户端待审核文件日期控件显示故障 #991，ios统一用PC端一样的js控件\n\t\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\t\t\ttype: \"datetime\"\n\t\t\t\t\t\t\t\tdisplayFormat: \"yyyy-MM-dd HH:mm\"\n\t\t\t\t\t\t\t\tpickerType: \"rollers\"\n\t\t\t\t\telse\n\t\t\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\t\ttype: \"steedos-date-mobile\"\n\t\t\t\t\t\t\tdateMobileOptions:\n\t\t\t\t\t\t\t\ttype: \"datetime\"\n\t\t\t\telse\n\t\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\t\ttype: \"datetime\"\n\t\t\t\t\t\t\tdisplayFormat: \"yyyy-MM-dd HH:mm\"\n\t\telse if field.type == \"[Object]\"\n\t\t\tfs.type = [Object]\n\t\telse if field.type == \"html\"\n\t\t\tfs.type = String\n\t\t\tif Meteor.isClient\n\t\t\t\tfs.autoform.type = 'steedosHtml';\n\t\t\t# if Meteor.isClient\n\t\t\t# \tlocale = Steedos.locale()\n\t\t\t# \tif locale == \"zh-cn\" || locale == \"zh-CN\"\n\t\t\t# \t\tlocale = \"zh-CN\"\n\t\t\t# \telse\n\t\t\t# \t\tlocale = \"en-US\"\n\t\t\t# \tfs.autoform.afFieldInput =\n\t\t\t# \t\ttype: \"summernote\"\n\t\t\t# \t\tclass: 'summernote-editor'\n\t\t\t# \t\tsettings:\n\t\t\t# \t\t\theight: 200\n\t\t\t# \t\t\tdialogsInBody: true\n\t\t\t# \t\t\ttoolbar:  [\n\t\t\t# \t\t\t\t['font1', ['style']],\n\t\t\t# \t\t\t\t['font2', ['bold', 'underline', 'italic', 'clear']],\n\t\t\t# \t\t\t\t['font3', ['fontname']],\n\t\t\t# \t\t\t\t['color', ['color']],\n\t\t\t# \t\t\t\t['para', ['ul', 'ol', 'paragraph']],\n\t\t\t# \t\t\t\t['table', ['table']],\n\t\t\t# \t\t\t\t['insert', ['link', 'picture']],\n\t\t\t# \t\t\t\t['view', ['codeview']]\n\t\t\t# \t\t\t]\n\t\t\t# \t\t\tfontNames: ['Arial', 'Comic Sans MS', 'Courier New', 'Helvetica', 'Impact', '宋体','黑体','微软雅黑','仿宋','楷体','隶书','幼圆']\n\t\t\t# \t\t\tlang: locale\n\n\t\telse if (field.type == \"lookup\" or field.type == \"master_detail\")\n\t\t\tfs.type = String\n\t\t\tfs.autoform.showIcon = field.showIcon\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\n\t\t\tif !field.hidden\n\n\t\t\t\tfs.autoform.filters = field.filters\n\n\t\t\t\tfs.autoform.dependOn = field.depend_on\n\n\t\t\t\tif field.beforeOpenFunction\n\t\t\t\t\tfs.beforeOpenFunction = field.beforeOpenFunction\n\n\t\t\t\tfs.filtersFunction = if field.filtersFunction then field.filtersFunction else Creator.evaluateFilters\n\n\t\t\t\tif field.optionsFunction\n\t\t\t\t\tfs.optionsFunction = field.optionsFunction\n\n\t\t\t\tif field.reference_to\n\n\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\tif field.createFunction && _.isFunction(field.createFunction)\n\t\t\t\t\t\t\tfs.createFunction = field.createFunction\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tif _.isString(field.reference_to)\n\t\t\t\t\t\t\t\t_ref_obj = Creator.Objects[field.reference_to]\n\t\t\t\t\t\t\t\tif _ref_obj?.permissions?.allowCreate\n\t\t\t\t\t\t\t\t\tfs.autoform.create = true\n\t\t\t\t\t\t\t\t\tfs.createFunction = (lookup_field)->\n\t\t\t\t\t\t\t\t\t\tModal.show(\"CreatorObjectModal\", {\n\t\t\t\t\t\t\t\t\t\t\tcollection: \"Creator.Collections.#{Creator.getCollection(field.reference_to)._name}\",\n\t\t\t\t\t\t\t\t\t\t\tformId: \"new#{field.reference_to.replace('.','_')}\",\n\t\t\t\t\t\t\t\t\t\t\tobject_name: \"#{field.reference_to}\",\n\t\t\t\t\t\t\t\t\t\t\toperation: \"insert\",\n\t\t\t\t\t\t\t\t\t\t\tonSuccess: (operation, result)->\n\t\t\t\t\t\t\t\t\t\t\t\tobject = Creator.getObject(result.object_name)\n\t\t\t\t\t\t\t\t\t\t\t\tif result.object_name == \"objects\"\n\t\t\t\t\t\t\t\t\t\t\t\t\tlookup_field.addItems([{label: result.value.label, value: result.value.name, icon: result.value.icon}], result.value.name)\n\t\t\t\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\t\t\t\tlookup_field.addItems([{label: result.value[object.NAME_FIELD_KEY] || result.value.label || result.value.name, value: result._id}], result._id)\n\t\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\tfs.autoform.create = false\n\n\t\t\t\t\tif _.isBoolean(field.create)\n\t\t\t\t\t\tfs.autoform.create = field.create\n\n\t\t\t\t\tif field.reference_sort\n\t\t\t\t\t\tfs.autoform.optionsSort = field.reference_sort\n\n\t\t\t\t\tif field.reference_limit\n\t\t\t\t\t\tfs.autoform.optionsLimit = field.reference_limit\n\t\t\t\t\tif field.reference_to_field\n\t\t\t\t\t\tfs.autoform.referenceToField = field.reference_to_field\n\n\t\t\t\t\tif field.reference_to == \"users\"\n\t\t\t\t\t\tfs.autoform.type = \"selectuser\"\n\t\t\t\t\t\tif !field.hidden && !field.omit\n\t\t\t\t\t\t\t# is_company_limited表示过滤数据时是否只显示本分部下的数据\n\t\t\t\t\t\t\t# is_company_limited可以被改写覆盖成true/false或其他function\n\t\t\t\t\t\t\tif field.is_company_limited == undefined\n\t\t\t\t\t\t\t\t# 未定义is_company_limited属性时默认处理逻辑：\n\t\t\t\t\t\t\t\t# 对当前对象有viewAllRecords权限则不限制所属分部列表查看权限，否则只显示当前所属分部\n\t\t\t\t\t\t\t\t# 注意不是reference_to对象的viewAllRecords权限，而是当前对象的\n\t\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\t\tpermissions = obj.permissions\n\t\t\t\t\t\t\t\t\tisUnLimited = permissions?.viewAllRecords\n\t\t\t\t\t\t\t\t\tif _.include([\"organizations\", \"users\", \"space_users\"], obj.name)\n\t\t\t\t\t\t\t\t\t\t# 如果字段所属对象是用户或组织，则是否限制显示所属分部部门与modifyAllRecords权限关联\n\t\t\t\t\t\t\t\t\t\tisUnLimited = permissions?.modifyAllRecords\n\t\t\t\t\t\t\t\t\tif isUnLimited\n\t\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = false\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = true\n\t\t\t\t\t\t\telse if _.isFunction field.is_company_limited\n\t\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\t\t# 传入当前对象的权限，在函数中根据权限计算是否要限制只查看本分部\n\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited(obj.permissions)\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t# 服务端用不到is_company_limited\n\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = true\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited\n\t\t\t\t\telse if field.reference_to == \"organizations\"\n\t\t\t\t\t\tfs.autoform.type = \"selectorg\"\n\t\t\t\t\t\tif !field.hidden && !field.omit\n\t\t\t\t\t\t\t# is_company_limited表示过滤数据时是否只显示本分部下的数据\n\t\t\t\t\t\t\t# is_company_limited可以被改写覆盖成true/false或其他function\n\t\t\t\t\t\t\tif field.is_company_limited == undefined\n\t\t\t\t\t\t\t\t# 未定义is_company_limited属性时默认处理逻辑：\n\t\t\t\t\t\t\t\t# 对当前对象有viewAllRecords权限则不限制所属分部列表查看权限，否则只显示当前所属分部\n\t\t\t\t\t\t\t\t# 注意不是reference_to对象的viewAllRecords权限，而是当前对象的\n\t\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\t\tpermissions = obj.permissions\n\t\t\t\t\t\t\t\t\tisUnLimited = permissions?.viewAllRecords\n\t\t\t\t\t\t\t\t\tif _.include([\"organizations\", \"users\", \"space_users\"], obj.name)\n\t\t\t\t\t\t\t\t\t\t# 如果字段所属对象是用户或组织，则是否限制显示所属分部部门与modifyAllRecords权限关联\n\t\t\t\t\t\t\t\t\t\tisUnLimited = permissions?.modifyAllRecords\n\t\t\t\t\t\t\t\t\tif isUnLimited\n\t\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = false\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = true\n\t\t\t\t\t\t\telse if _.isFunction field.is_company_limited\n\t\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\t\t# 传入当前对象的权限，在函数中根据权限计算是否要限制只查看本分部\n\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited(obj.permissions)\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t# 服务端用不到is_company_limited\n\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = true\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited\n\t\t\t\t\telse\n\t\t\t\t\t\tif typeof(field.reference_to) == \"function\"\n\t\t\t\t\t\t\t_reference_to = field.reference_to()\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t_reference_to = field.reference_to\n\n\t\t\t\t\t\tif _.isArray(_reference_to)\n\t\t\t\t\t\t\tfs.type = Object\n\t\t\t\t\t\t\tfs.blackbox = true\n\t\t\t\t\t\t\tfs.autoform.objectSwitche = true\n\n\t\t\t\t\t\t\tschema[field_name + \".o\"] = {\n\t\t\t\t\t\t\t\ttype: String\n\t\t\t\t\t\t\t\tautoform: {omit: true}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tschema[field_name + \".ids\"] = {\n\t\t\t\t\t\t\t\ttype: [String]\n\t\t\t\t\t\t\t\tautoform: {omit: true}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t_reference_to = [_reference_to]\n\n\t\t\t\t\t\t_object = Creator.Objects[_reference_to[0]]\n\t\t\t\t\t\tif _object and _object.enable_tree\n\t\t\t\t\t\t\tfs.autoform.type = \"selectTree\"\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tfs.autoform.type = \"steedosLookups\"\n\t\t\t\t\t\t\tfs.autoform.optionsMethod = field.optionsMethod || \"creator.object_options\"\n\n\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\tfs.autoform.optionsMethodParams = ()->\n\t\t\t\t\t\t\t\t\treturn {space: Session.get(\"spaceId\")}\n\t\t\t\t\t\t\t\tfs.autoform.references = []\n\t\t\t\t\t\t\t\t_reference_to.forEach (_reference)->\n\t\t\t\t\t\t\t\t\t_object = Creator.Objects[_reference]\n\t\t\t\t\t\t\t\t\tif _object\n\t\t\t\t\t\t\t\t\t\tfs.autoform.references.push {\n\t\t\t\t\t\t\t\t\t\t\tobject: _reference\n\t\t\t\t\t\t\t\t\t\t\tlabel: _object?.label\n\t\t\t\t\t\t\t\t\t\t\ticon: _object?.icon\n\t\t\t\t\t\t\t\t\t\t\tlink: ()->\n\t\t\t\t\t\t\t\t\t\t\t\treturn \"/app/#{Session.get('app_id')}/#{_reference}/view/\"\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tfs.autoform.references.push {\n\t\t\t\t\t\t\t\t\t\t\tobject: _reference\n\t\t\t\t\t\t\t\t\t\t\tlink: ()->\n\t\t\t\t\t\t\t\t\t\t\t\treturn \"/app/#{Session.get('app_id')}/#{_reference}/view/\"\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\telse\n\t\t\t\t\tfs.autoform.type = \"steedosLookups\"\n\t\t\t\t\tfs.autoform.defaultIcon = field.defaultIcon\n\n\t\telse if field.type == \"select\"\n\t\t\tfs.type = String\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tfs.autoform.type = \"steedosLookups\"\n\t\t\t\tfs.autoform.showIcon = false\n\t\t\t\tfs.autoform.options = field.options\n\t\t\telse\n\t\t\t\tfs.autoform.type = \"select\"\n\t\t\t\tfs.autoform.options = field.options\n\t\t\t\tif _.has(field, 'firstOption')\n\t\t\t\t\tfs.autoform.firstOption = field.firstOption\n\t\t\t\telse\n\t\t\t\t\tfs.autoform.firstOption = \"\"\n\t\t\t# 因为列表视图右侧过滤器还是用的老表单的lookup和select控件，所以上面的代码始终保持原样需要执行\n\t\t\t# 下面是配置了data_type时，额外处理的逻辑\n\t\t\tif field.data_type and field.data_type != \"text\"\n\t\t\t\tif [\"number\", \"currency\", \"percent\"].indexOf(field.data_type) > -1\n\t\t\t\t\tfsType = Number\n\t\t\t\t\tfs.decimal = true\n\t\t\t\telse if field.data_type == \"boolean\"\n\t\t\t\t\tfsType = Boolean\n\t\t\t\telse\n\t\t\t\t\tfsType = String\n\t\t\t\tfs.type = fsType\n\t\t\t\tif field.multiple\n\t\t\t\t\tfs.type = [fsType]\n\t\t\t\t\t\n\t\t\t\tfs.autoform.options = Creator.getSelectOptions(field)\n\t\telse if field.type == \"currency\"\n\t\t\tfs.type = Number\n\t\t\tfs.autoform.type = \"steedosNumber\"\n\t\t\tfs.autoform.precision = field.precision || 18\n\t\t\tif field?.scale\n\t\t\t\tfs.autoform.scale = field.scale\n\t\t\t\tfs.decimal = true\n\t\t\telse if field?.scale != 0\n\t\t\t\tfs.autoform.scale = 2\n\t\t\t\tfs.decimal = true\n\t\telse if field.type == \"number\"\n\t\t\tfs.type = Number\n\t\t\tfs.autoform.type = \"steedosNumber\"\n\t\t\tfs.autoform.precision = field.precision || 18\n\t\t\tif field?.scale\n\t\t\t\tfs.autoform.scale = field.scale\n\t\t\t\tfs.decimal = true\n\t\telse if field.type == \"boolean\"\n\t\t\tfs.type = Boolean\n\t\t\tif field.readonly\n\t\t\t\tfs.autoform.disabled = true\n\t\t\tfs.autoform.type = \"steedos-boolean-checkbox\"\n\t\telse if field.type == \"toggle\"\n\t\t\tfs.type = Boolean\n\t\t\tif field.readonly\n\t\t\t\tfs.autoform.disabled = true\n\t\t\tfs.autoform.type = \"steedos-boolean-toggle\"\n\t\telse if field.type == \"reference\"\n\t\t\tfs.type = String\n\t\telse if field.type == \"checkbox\"\n\t\t\tfs.type = [String]\n\t\t\tfs.autoform.type = \"select-checkbox\"\n\t\t\tfs.autoform.options = field.options\n\t\telse if field.type == \"file\"\n\t\t\tcollectionName = field.collection || \"files\" # collection 默认是 'files'\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: collectionName\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = collectionName\n\t\telse if field.type == \"filesize\"\n\t\t\tfs.type = Number\n\t\t\tfs.autoform.type = 'filesize'\n\t\telse if field.type == \"Object\" || field.type == \"object\"\n\t\t\tfs.type = Object\n\t\telse if field.type == \"grid\" || field.type == \"table\"\n\t\t\tfs.type = Array\n\t\t\tfs.autoform.editable = true\n\t\t\tfs.autoform.type = \"steedosGrid\"\n\n\t\t\tschema[field_name + \".$\"] =\n\t\t\t\ttype: Object\n\t\telse if field.type == \"image\"\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: 'images'\n\t\t\t\t\t\taccept: 'image/*'\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = 'images'\n\t\t\t\tfs.autoform.accept = 'image/*'\n\t\telse if field.type == \"avatar\"\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: 'avatars'\n\t\t\t\t\t\taccept: 'image/*'\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = 'avatars'\n\t\t\t\tfs.autoform.accept = 'image/*'\n\t\telse if field.type == \"audio\"\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: 'audios'\n\t\t\t\t\t\taccept: 'audio/*'\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = 'audios'\n\t\t\t\tfs.autoform.accept = 'audio/*'\n\t\telse if field.type == \"video\"\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: 'videos'\n\t\t\t\t\t\taccept: 'video/*'\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = 'videos'\n\t\t\t\tfs.autoform.accept = 'video/*'\n\t\telse if field.type == \"location\"\n\t\t\tfs.type = Object\n\t\t\tfs.autoform.type = \"location\"\n\t\t\tfs.autoform.system = field.system || \"wgs84\"\n\t\t\tfs.blackbox = true\n\t\telse if field.type == \"markdown\"\n\t\t\tfs.type = String\n\t\t\tfs.autoform.type = \"text\"\n\t\telse if field.type == 'url'\n\t\t\tfs.type = String\n\t\t\t# fs.regEx = SimpleSchema.RegEx.Url\n\t\t\tfs.autoform.type = 'steedosUrl'\n\t\telse if field.type == 'email'\n\t\t\tfs.type = String\n\t\t\tfs.regEx = SimpleSchema.RegEx.Email\n\t\t\tfs.autoform.type = 'steedosEmail'\n\t\telse if field.type == 'autonumber'\n\t\t\tfs.type = String\n\t\telse if field.type == 'color'\n\t\t\tfs.type = String\n\t\telse if field.type == 'formula'\n\t\t\tfs = Creator.getObjectSchema({fields: {field: Object.assign({}, field, {type: field.data_type})}})[field.name]\n\t\telse if field.type == 'summary'\n\t\t\tfs = Creator.getObjectSchema({fields: {field: Object.assign({}, field, {type: field.data_type})}})[field.name]\n\t\t# else if field.type == 'select'\n\t\t# \tfs = Creator.getObjectSchema({fields: {field: Object.assign({}, field, {type: field.data_type})}})[field.name]\n\t\telse if field.type == 'percent'\n\t\t\tfs.type = Number\n\t\t\tfs.autoform.type = \"steedosNumber\"\n\t\t\tfs.autoform.precision = field.precision || 18\n\t\t\tunless _.isNumber(field.scale)\n\t\t\t\t# 没配置小数位数则按小数位数0来处理，即默认显示为整数的百分比，比如20%，此时控件可以输入2位小数，转成百分比就是整数\n\t\t\t\tfield.scale = 0\n\t\t\t# autoform控件中小数位数始终比配置的位数多2位\n\t\t\tfs.autoform.scale = field.scale + 2\n\t\t\tfs.decimal = true\n\t\telse\n\t\t\tfs.type = field.type\n\n\t\tif field.label\n\t\t\tfs.label = field.label\n\n#\t\tif field.allowedValues\n#\t\t\tfs.allowedValues = field.allowedValues\n\n\t\tif !field.required\n\t\t\tfs.optional = true\n\n\t\t# [签约对象同时配置了company_ids必填及uneditable_fields造成部分用户新建签约对象时报错 #192](https://github.com/steedos/steedos-project-dzug/issues/192)\n\t\t# 后台始终设置required为false\n\t\tif !Meteor.isClient\n\t\t\tfs.optional = true\n\n\t\tif field.unique\n\t\t\tfs.unique = true\n\n\t\tif field.omit\n\t\t\tfs.autoform.omit = true\n\n\t\tif field.group\n\t\t\tfs.autoform.group = field.group\n\n\t\tif field.is_wide\n\t\t\tfs.autoform.is_wide = true\n\n\t\tif field.hidden\n\t\t\tfs.autoform.type = \"hidden\"\n\n\t\tif (field.type == \"select\") or (field.type == \"lookup\") or (field.type == \"master_detail\")\n\t\t\tif typeof(field.filterable) == 'undefined'\n\t\t\t\tfield.filterable = true\n\t\tif field.name == 'name' || field.is_name\n\t\t\tif typeof(field.searchable) == 'undefined'\n\t\t\t\tfield.searchable = true\n\n\t\tif autoform_type\n\t\t\tfs.autoform.type = autoform_type\n\n\t\tif field.defaultValue\n\t\t\tif Meteor.isClient and Creator.Formular.checkFormula(field.defaultValue)\n\t\t\t\tfs.autoform.defaultValue = ()->\n\t\t\t\t\treturn Creator.Formular.run(field.defaultValue, {userId: Meteor.userId(), spaceId: Session.get(\"spaceId\"), now: new Date()})\n\t\t\telse\n\t\t\t\tfs.autoform.defaultValue = field.defaultValue\n\t\t\t# \tif !_.isFunction(field.defaultValue)\n\t\t\t# \t\tfs.defaultValue = field.defaultValue\n\n\t\tif field.readonly\n\t\t\tfs.autoform.readonly = true\n\n\t\tif field.disabled\n\t\t\tfs.autoform.disabled = true\n\n\t\tif field.inlineHelpText\n\t\t\tfs.autoform.inlineHelpText = field.inlineHelpText\n\n\t\tif field.blackbox\n\t\t\tfs.blackbox = true\n\n\t\tif _.has(field, 'min')\n\t\t\tfs.min = field.min\n\t\tif _.has(field, 'max')\n\t\t\tfs.max = field.max\n\n\t\t# 只有生产环境才重建索引\n\t\tif Meteor.isProduction\n\t\t\tif field.index\n\t\t\t\tfs.index = field.index\n\t\t\telse if field.sortable\n\t\t\t\tfs.index = true\n\n\t\tschema[field_name] = fs\n\n\treturn schema\n\n\nCreator.getFieldDisplayValue = (object_name, field_name, field_value)->\n\thtml = field_value\n\tobject = Creator.getObject(object_name)\n\tif !object\n\t\treturn \"\"\n\tfield = object.fields(field_name)\n\tif !field\n\t\treturn \"\"\n\n\tif field.type == \"datetime\"\n\t\thtml = moment(this.val).format('YYYY-MM-DD H:mm')\n\telse if field.type == \"date\"\n\t\thtml = moment(this.val).format('YYYY-MM-DD')\n\n\treturn html\n\nCreator.checkFieldTypeSupportBetweenQuery = (field_type)->\n\treturn [\"date\", \"datetime\", \"time\", \"currency\", \"number\"].includes(field_type)\n\nCreator.pushBetweenBuiltinOptionals = (field_type, operations)->\n\tbuiltinValues = Creator.getBetweenBuiltinValues(field_type)\n\tif builtinValues\n\t\t_.forEach builtinValues, (builtinItem, key)->\n\t\t\toperations.push({label: builtinItem.label, value: key})\n\nCreator.getBetweenBuiltinValues = (field_type, is_check_only)->\n\t# 过滤器字段类型对应的内置选项\n\tif [\"date\", \"datetime\"].includes(field_type)\n\t\treturn Creator.getBetweenTimeBuiltinValues(is_check_only, field_type)\n\nCreator.getBetweenBuiltinValueItem = (field_type, key)->\n\t# 过滤器字段类型对应的内置选项\n\tif [\"date\", \"datetime\"].includes(field_type)\n\t\treturn Creator.getBetweenTimeBuiltinValueItem(field_type, key)\n\nCreator.getBetweenBuiltinOperation = (field_type, value)->\n\t# 根据过滤器的过滤值，获取对应的内置运算符\n\t# 比如value为last_year，返回between_time_last_year\n\tunless _.isString(value)\n\t\treturn\n\tbetweenBuiltinValues = Creator.getBetweenBuiltinValues(field_type)\n\tunless betweenBuiltinValues\n\t\treturn\n\tresult = null\n\t_.each betweenBuiltinValues, (item, operation)->\n\t\tif item.key == value\n\t\t\tresult = operation\n\treturn result\n\n# 如果只是为判断operation是否存在，则没必要计算values，传入is_check_only为true即可\nCreator.getBetweenTimeBuiltinValues = (is_check_only, field_type)->\n\t# 过滤器时间字段类型对应的内置选项\n\treturn {\n\t\t\"between_time_last_year\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_year\"),\n\t\t\"between_time_this_year\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_year\"),\n\t\t\"between_time_next_year\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_year\"),\n\t\t\"between_time_last_quarter\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_quarter\"),\n\t\t\"between_time_this_quarter\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_quarter\"),\n\t\t\"between_time_next_quarter\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_quarter\"),\n\t\t\"between_time_last_month\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_month\"),\n\t\t\"between_time_this_month\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_month\"),\n\t\t\"between_time_next_month\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_month\"),\n\t\t\"between_time_last_week\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_week\"),\n\t\t\"between_time_this_week\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_week\"),\n\t\t\"between_time_next_week\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_week\"),\n\t\t\"between_time_yestday\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"yestday\"),\n\t\t\"between_time_today\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"today\"),\n\t\t\"between_time_tomorrow\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"tomorrow\"),\n\t\t\"between_time_last_7_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_7_days\"),\n\t\t\"between_time_last_30_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_30_days\"),\n\t\t\"between_time_last_60_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_60_days\"),\n\t\t\"between_time_last_90_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_90_days\"),\n\t\t\"between_time_last_120_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_120_days\"),\n\t\t\"between_time_next_7_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_7_days\"),\n\t\t\"between_time_next_30_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_30_days\"),\n\t\t\"between_time_next_60_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_60_days\"),\n\t\t\"between_time_next_90_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_90_days\"),\n\t\t\"between_time_next_120_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_120_days\")\n\t}\n\nCreator.getQuarterStartMonth = (month)->\n\tif !month\n\t\tmonth = new Date().getMonth()\n\t\n\tif month < 3\n\t\treturn 0\n\telse if month < 6\n\t\treturn 3\n\telse if month < 9\n\t\treturn 6\n\t\n\treturn 9\n\n\nCreator.getLastQuarterFirstDay = (year,month)->\n\tif !year\n\t\tyear = new Date().getFullYear()\n\tif !month\n\t\tmonth = new Date().getMonth()\n\t\n\tif month < 3\n\t\tyear--\n\t\tmonth = 9\n\telse if month < 6\n\t\tmonth = 0\n\telse if month < 9\n\t\tmonth = 3\n\telse \n\t\tmonth = 6\n\t\n\treturn new Date(year, month, 1)\n\t\n\nCreator.getNextQuarterFirstDay = (year,month)->\n\tif !year\n\t\tyear = new Date().getFullYear()\n\tif !month\n\t\tmonth = new Date().getMonth()\n\t\n\tif month < 3\n\t\tmonth = 3\n\telse if month < 6\n\t\tmonth = 6\n\telse if month < 9\n\t\tmonth = 9\n\telse\n\t\tyear++\n\t\tmonth = 0\n\t\n\treturn new Date(year, month, 1)\n\nCreator.getMonthDays = (year,month)->\n\tif month == 11\n\t\treturn 31\n\t\n\tmillisecond = 1000 * 60 * 60 * 24\n\tstartDate = new Date(year, month, 1)\n\tendDate = new Date(year, month+1, 1)\n\tdays = (endDate-startDate)/millisecond\n\treturn days\n\nCreator.getLastMonthFirstDay = (year, month)->\n\tif !year\n\t\tyear = new Date().getFullYear()\n\tif !month\n\t\tmonth = new Date().getMonth()\n\t\n\t# 月份为0代表本年的第一月\n\tif month == 0\n\t\tmonth = 11\n\t\tyear--\n\t\treturn new Date(year, month, 1)\n\t\n\t# 否则,只减去月份\n\tmonth--;\n\treturn new Date(year, month, 1)\n\t\nCreator.getBetweenTimeBuiltinValueItem = (field_type, key)->\n\t# 过滤器between运算符，现算日期/日期时间类型字段的values值\n\tnow = new Date()\n\t# 一天的毫秒数\n\tmillisecond = 1000 * 60 * 60 * 24\n\tyestday = new Date(now.getTime() - millisecond)\n\ttomorrow = new Date(now.getTime() + millisecond)\n\t# 一周中的某一天\n\tweek = now.getDay()\n\t# 减去的天数\n\tminusDay = if week != 0 then week - 1 else 6\n\tmonday = new Date(now.getTime() - (minusDay * millisecond))\n\tsunday = new Date(monday.getTime() + (6 * millisecond))\n\t# 上周日\n\tlastSunday = new Date(monday.getTime() - millisecond)\n\t# 上周一\n\tlastMonday = new Date(lastSunday.getTime() - (millisecond * 6))\n\t# 下周一\n\tnextMonday = new Date(sunday.getTime() + millisecond)\n\t# 下周日\n\tnextSunday = new Date(nextMonday.getTime() + (millisecond * 6))\n\tcurrentYear = now.getFullYear()\n\tpreviousYear = currentYear - 1\n\tnextYear = currentYear + 1\n\t# 当前月份\n\tcurrentMonth = now.getMonth()\n\t# 计数年、月\n\tyear = now.getFullYear()\n\tmonth = now.getMonth()\n\t# 本月第一天\n\tfirstDay = new Date(currentYear,currentMonth,1)\n\n\t# 当为12月的时候年份需要加1\n\t# 月份需要更新为0 也就是下一年的第一个月\n\tif currentMonth == 11\n\t\tyear++\n\t\tmonth++\n\telse\n\t\tmonth++\n\t\n\t# 下月第一天\n\tnextMonthFirstDay = new Date(year, month, 1)\n\t# 下月最后一天\n\tnextMonthFinalDay = new Date(year,month,Creator.getMonthDays(year,month))\n\t# 本月最后一天\n\tlastDay = new Date(nextMonthFirstDay.getTime() - millisecond)\n\t# 上月第一天\n\tlastMonthFirstDay = Creator.getLastMonthFirstDay(currentYear,currentMonth)\n\t# 上月最后一天\n\tlastMonthFinalDay = new Date(firstDay.getTime() - millisecond)\n\t# 本季度开始日\n\tthisQuarterStartDay = new Date(currentYear,Creator.getQuarterStartMonth(currentMonth),1)\n\t# 本季度结束日\n\tthisQuarterEndDay = new Date(currentYear,Creator.getQuarterStartMonth(currentMonth)+2,Creator.getMonthDays(currentYear,Creator.getQuarterStartMonth(currentMonth)+2))\n\t# 上季度开始日\n\tlastQuarterStartDay = Creator.getLastQuarterFirstDay(currentYear,currentMonth)\n\t# 上季度结束日\n\tlastQuarterEndDay = new Date(lastQuarterStartDay.getFullYear(),lastQuarterStartDay.getMonth()+2,Creator.getMonthDays(lastQuarterStartDay.getFullYear(),lastQuarterStartDay.getMonth()+2))\n\t# 下季度开始日\n\tnextQuarterStartDay = Creator.getNextQuarterFirstDay(currentYear,currentMonth)\n\t# 下季度结束日\n\tnextQuarterEndDay = new Date(nextQuarterStartDay.getFullYear(),nextQuarterStartDay.getMonth()+2,Creator.getMonthDays(nextQuarterStartDay.getFullYear(),nextQuarterStartDay.getMonth()+2))\n\t# 过去7天 \n\tlast_7_days = new Date(now.getTime() - (6 * millisecond))\n\t# 过去30天\n\tlast_30_days = new Date(now.getTime() - (29 * millisecond))\n\t# 过去60天\n\tlast_60_days = new Date(now.getTime() - (59 * millisecond))\n\t# 过去90天\n\tlast_90_days = new Date(now.getTime() - (89 * millisecond))\n\t# 过去120天\n\tlast_120_days = new Date(now.getTime() - (119 * millisecond))\n\t# 未来7天 \n\tnext_7_days = new Date(now.getTime() + (6 * millisecond))\n\t# 未来30天\n\tnext_30_days = new Date(now.getTime() + (29 * millisecond))\n\t# 未来60天\n\tnext_60_days = new Date(now.getTime() + (59 * millisecond))\n\t# 未来90天\n\tnext_90_days = new Date(now.getTime() + (89 * millisecond))\n\t# 未来120天\n\tnext_120_days = new Date(now.getTime() + (119 * millisecond))\n\n\tswitch key\n\t\twhen \"last_year\"\n\t\t\t#去年\n\t\t\tlabel = t(\"creator_filter_operation_between_last_year\")\n\t\t\tstartValue = new Date(\"#{previousYear}-01-01T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{previousYear}-12-31T23:59:59Z\")\n\t\twhen \"this_year\"\n\t\t\t#今年\n\t\t\tlabel = t(\"creator_filter_operation_between_this_year\")\n\t\t\tstartValue = new Date(\"#{currentYear}-01-01T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{currentYear}-12-31T23:59:59Z\")\n\t\twhen \"next_year\"\n\t\t\t#明年\n\t\t\tlabel = t(\"creator_filter_operation_between_next_year\")\n\t\t\tstartValue = new Date(\"#{nextYear}-01-01T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{nextYear}-12-31T23:59:59Z\")\n\t\twhen \"last_quarter\"\n\t\t\t#上季度\n\t\t\tstrFirstDay = moment(lastQuarterStartDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(lastQuarterEndDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_quarter\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"this_quarter\"\n\t\t\t#本季度\n\t\t\tstrFirstDay = moment(thisQuarterStartDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(thisQuarterEndDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_this_quarter\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"next_quarter\"\n\t\t\t#下季度\n\t\t\tstrFirstDay = moment(nextQuarterStartDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(nextQuarterEndDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_quarter\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"last_month\"\n\t\t\t#上月\n\t\t\tstrFirstDay = moment(lastMonthFirstDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(lastMonthFinalDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_month\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"this_month\"\n\t\t\t#本月\n\t\t\tstrFirstDay = moment(firstDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(lastDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_this_month\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"next_month\"\n\t\t\t#下月\n\t\t\tstrFirstDay = moment(nextMonthFirstDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(nextMonthFinalDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_month\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"last_week\"\n\t\t\t#上周\n\t\t\tstrMonday = moment(lastMonday).format(\"YYYY-MM-DD\")\n\t\t\tstrSunday = moment(lastSunday).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_week\")\n\t\t\tstartValue = new Date(\"#{strMonday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strSunday}T23:59:59Z\")\n\t\twhen \"this_week\"\n\t\t\t#本周\n\t\t\tstrMonday = moment(monday).format(\"YYYY-MM-DD\")\n\t\t\tstrSunday = moment(sunday).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_this_week\")\n\t\t\tstartValue = new Date(\"#{strMonday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strSunday}T23:59:59Z\")\n\t\twhen \"next_week\"\n\t\t\t#下周\n\t\t\tstrMonday = moment(nextMonday).format(\"YYYY-MM-DD\")\n\t\t\tstrSunday = moment(nextSunday).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_week\")\n\t\t\tstartValue = new Date(\"#{strMonday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strSunday}T23:59:59Z\")\n\t\twhen \"yestday\"\n\t\t\t#昨天\n\t\t\tstrYestday = moment(yestday).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_yestday\")\n\t\t\tstartValue = new Date(\"#{strYestday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strYestday}T23:59:59Z\")\n\t\twhen \"today\"\n\t\t\t#今天\n\t\t\tstrToday = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_today\")\n\t\t\tstartValue = new Date(\"#{strToday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strToday}T23:59:59Z\")\n\t\twhen \"tomorrow\"\n\t\t\t#明天\n\t\t\tstrTomorrow = moment(tomorrow).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_tomorrow\")\n\t\t\tstartValue = new Date(\"#{strTomorrow}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strTomorrow}T23:59:59Z\")\n\t\twhen \"last_7_days\"\n\t\t\t#过去7天\n\t\t\tstrStartDay = moment(last_7_days).format(\"YYYY-MM-DD\") \n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_7_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"last_30_days\"\n\t\t\t#过去30天\n\t\t\tstrStartDay = moment(last_30_days).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_30_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"last_60_days\"\n\t\t\t#过去60天\n\t\t\tstrStartDay = moment(last_60_days).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_60_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"last_90_days\"\n\t\t\t#过去90天\n\t\t\tstrStartDay = moment(last_90_days).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_90_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"last_120_days\"\n\t\t\t#过去120天\n\t\t\tstrStartDay = moment(last_120_days).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_120_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_7_days\"\n\t\t\t#未来7天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_7_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_7_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_30_days\"\n\t\t\t#未来30天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_30_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_30_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_60_days\"\n\t\t\t#未来60天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_60_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_60_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_90_days\"\n\t\t\t#未来90天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_90_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_90_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_120_days\"\n\t\t\t#未来120天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_120_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_120_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\n\tvalues = [startValue, endValue]\n\tif field_type == \"datetime\"\n\t\t# 时间类型字段，内置时间范围应该考虑偏移时区值，否则过滤数据存在偏差\n\t\t# 非内置时间范围时，用户通过时间控件选择的范围，会自动处理时区偏差情况\n\t\t# 日期类型字段，数据库本来就存的是UTC的0点，不存在偏差\n\t\t_.forEach values, (fv)->\n\t\t\tif fv\n\t\t\t\tfv.setHours(fv.getHours() + fv.getTimezoneOffset() / 60 )\n\t\n\treturn {\n\t\tlabel: label\n\t\tkey: key\n\t\tvalues: values\n\t}\n\nCreator.getFieldDefaultOperation = (field_type)->\n\tif field_type && Creator.checkFieldTypeSupportBetweenQuery(field_type)\n\t\treturn 'between'\n\telse if [\"textarea\", \"text\", \"code\"].includes(field_type)\n\t\treturn 'contains'\n\telse\n\t\treturn \"=\"\n\nCreator.getFieldOperation = (field_type) ->\n\t# 日期类型: date, datetime  支持操作符: \"=\", \"<>\", \"<\", \">\", \"<=\", \">=\"\n\t# 文本类型: text, textarea, html  支持操作符: \"=\", \"<>\", \"contains\", \"notcontains\", \"startswith\"\n\t# 选择类型: lookup, master_detail, select 支持操作符: \"=\", \"<>\"\n\t# 数值类型: currency, number  支持操作符: \"=\", \"<>\", \"<\", \">\", \"<=\", \">=\"\n\t# 布尔类型: boolean  支持操作符: \"=\", \"<>\"\n\t# 数组类型: checkbox, [text]  支持操作符: \"=\", \"<>\"\n\n\toptionals = {\n\t\tequal: {label: t(\"creator_filter_operation_equal\"), value: \"=\"},\n\t\tunequal: {label: t(\"creator_filter_operation_unequal\"), value: \"<>\"},\n\t\tless_than: {label: t(\"creator_filter_operation_less_than\"), value: \"<\"},\n\t\tgreater_than: {label: t(\"creator_filter_operation_greater_than\"), value: \">\"},\n\t\tless_or_equal: {label: t(\"creator_filter_operation_less_or_equal\"), value: \"<=\"},\n\t\tgreater_or_equal: {label: t(\"creator_filter_operation_greater_or_equal\"), value: \">=\"},\n\t\tcontains: {label: t(\"creator_filter_operation_contains\"), value: \"contains\"},\n\t\tnot_contain: {label: t(\"creator_filter_operation_does_not_contain\"), value: \"notcontains\"},\n\t\tstarts_with: {label: t(\"creator_filter_operation_starts_with\"), value: \"startswith\"},\n\t\tbetween: {label: t(\"creator_filter_operation_between\"), value: \"between\"},\n\t}\n\n\tif field_type == undefined\n\t\treturn _.values(optionals)\n\n\toperations = []\n\n\tif Creator.checkFieldTypeSupportBetweenQuery(field_type)\n\t\toperations.push(optionals.between)\n\t\tCreator.pushBetweenBuiltinOptionals(field_type, operations)\n\telse if field_type == \"text\" or field_type == \"textarea\" or field_type == \"html\" or field_type == \"code\"\n#\t\toperations.push(optionals.equal, optionals.unequal, optionals.contains, optionals.not_contain, optionals.starts_with)\n\t\toperations.push(optionals.contains)\n\telse if field_type == \"lookup\" or field_type == \"master_detail\" or field_type == \"select\"\n\t\toperations.push(optionals.equal, optionals.unequal)\n\telse if field_type == \"currency\" or field_type == \"number\"\n\t\toperations.push(optionals.equal, optionals.unequal, optionals.less_than, optionals.greater_than, optionals.less_or_equal, optionals.greater_or_equal)\n\telse if field_type == \"boolean\"\n\t\toperations.push(optionals.equal, optionals.unequal)\n\telse if field_type == \"checkbox\"\n\t\toperations.push(optionals.equal, optionals.unequal)\n\telse if field_type == \"[text]\"\n\t\toperations.push(optionals.equal, optionals.unequal)\n\telse\n\t\toperations.push(optionals.equal, optionals.unequal)\n\n\treturn operations\n\n###\n    先按照有排序号的小的在前，大的在后\n    再将没有排序号的显示在\n###\nCreator.getObjectFieldsName = (object_name)->\n\tfields = Creator.getObject(object_name)?.fields\n\tfieldsArr = []\n\n\t_.each fields, (field)->\n\t\tfieldsArr.push {name: field.name, sort_no: field.sort_no}\n\n\tfieldsName = []\n\t_.each _.sortBy(fieldsArr, \"sort_no\"), (field)->\n\t\tfieldsName.push(field.name)\n\treturn fieldsName\n","Creator.getSelectOptions = function(fieldSchema) {\n  var data_type, options;\n  options = fieldSchema.options;\n  if (!options) {\n    return;\n  }\n  data_type = fieldSchema.data_type;\n  if (!_.isFunction(options) && data_type && data_type !== 'text') {\n    options.forEach(function(optionItem) {\n      if (typeof optionItem.value !== 'string') {\n        return;\n      }\n      if (['number', 'currency', 'percent'].indexOf(data_type) > -1) {\n        return optionItem.value = Number(optionItem.value);\n      } else if (data_type === 'boolean') {\n        return optionItem.value = optionItem.value === 'true';\n      }\n    });\n  }\n  return options;\n};\n\nCreator.getObjectSchema = function(obj) {\n  var fieldsArr, schema;\n  if (!obj) {\n    return;\n  }\n  schema = {};\n  fieldsArr = [];\n  _.each(obj.fields, function(field, field_name) {\n    if (!_.has(field, \"name\")) {\n      field.name = field_name;\n    }\n    return fieldsArr.push(field);\n  });\n  _.each(_.sortBy(fieldsArr, \"sort_no\"), function(field) {\n    var _object, _ref_obj, _reference_to, autoform_type, collectionName, field_name, fs, fsType, isUnLimited, permissions, ref, ref1;\n    field_name = field.name;\n    fs = {};\n    if (field.regEx) {\n      fs.regEx = field.regEx;\n    }\n    fs.autoform = {};\n    fs.autoform.multiple = field.multiple;\n    fs.autoform.reference_to = field.reference_to;\n    autoform_type = (ref = field.autoform) != null ? ref.type : void 0;\n    if (field.type === \"text\" || field.type === \"phone\") {\n      fs.type = String;\n      if (field.multiple) {\n        fs.type = [String];\n        fs.autoform.type = \"tags\";\n      }\n    } else if (field.type === \"[text]\" || field.type === \"[phone]\") {\n      fs.type = [String];\n      fs.autoform.type = \"tags\";\n    } else if (field.type === 'code') {\n      fs.type = String;\n      fs.autoform.type = \"widearea\";\n      fs.autoform.rows = field.rows || 12;\n      if (field.language) {\n        fs.autoform.language = field.language;\n      }\n    } else if (field.type === \"textarea\") {\n      fs.type = String;\n      fs.autoform.type = \"widearea\";\n      fs.autoform.rows = field.rows || 2;\n    } else if (field.type === \"password\") {\n      fs.type = String;\n      fs.autoform.type = \"password\";\n    } else if (field.type === \"date\") {\n      fs.type = Date;\n      if (Meteor.isClient) {\n        if (Steedos.isMobile() || Steedos.isPad()) {\n          if (Steedos.isiOS()) {\n            fs.autoform.afFieldInput = {\n              type: \"dx-date-box\",\n              timezoneId: \"utc\",\n              dxDateBoxOptions: {\n                type: \"date\",\n                displayFormat: \"yyyy-MM-dd\",\n                pickerType: \"rollers\"\n              }\n            };\n          } else {\n            fs.autoform.afFieldInput = {\n              type: \"steedos-date-mobile\",\n              dateMobileOptions: {\n                type: \"date\"\n              }\n            };\n          }\n        } else {\n          fs.autoform.outFormat = 'yyyy-MM-dd';\n          fs.autoform.afFieldInput = {\n            type: \"dx-date-box\",\n            timezoneId: \"utc\",\n            dxDateBoxOptions: {\n              type: \"date\",\n              displayFormat: \"yyyy-MM-dd\"\n            }\n          };\n        }\n      }\n    } else if (field.type === \"time\") {\n      fs.type = Date;\n      if (Meteor.isClient) {\n        fs.autoform.afFieldInput = {\n          type: \"dx-date-box\",\n          timezoneId: \"utc\",\n          dxDateBoxOptions: {\n            type: \"time\",\n            displayFormat: \"HH:mm\"\n          }\n        };\n      }\n    } else if (field.type === \"datetime\") {\n      fs.type = Date;\n      if (Meteor.isClient) {\n        if (Steedos.isMobile() || Steedos.isPad()) {\n          if (Steedos.isiOS()) {\n            fs.autoform.afFieldInput = {\n              type: \"dx-date-box\",\n              dxDateBoxOptions: {\n                type: \"datetime\",\n                displayFormat: \"yyyy-MM-dd HH:mm\",\n                pickerType: \"rollers\"\n              }\n            };\n          } else {\n            fs.autoform.afFieldInput = {\n              type: \"steedos-date-mobile\",\n              dateMobileOptions: {\n                type: \"datetime\"\n              }\n            };\n          }\n        } else {\n          fs.autoform.afFieldInput = {\n            type: \"dx-date-box\",\n            dxDateBoxOptions: {\n              type: \"datetime\",\n              displayFormat: \"yyyy-MM-dd HH:mm\"\n            }\n          };\n        }\n      }\n    } else if (field.type === \"[Object]\") {\n      fs.type = [Object];\n    } else if (field.type === \"html\") {\n      fs.type = String;\n      if (Meteor.isClient) {\n        fs.autoform.type = 'steedosHtml';\n      }\n    } else if (field.type === \"lookup\" || field.type === \"master_detail\") {\n      fs.type = String;\n      fs.autoform.showIcon = field.showIcon;\n      if (field.multiple) {\n        fs.type = [String];\n      }\n      if (!field.hidden) {\n        fs.autoform.filters = field.filters;\n        fs.autoform.dependOn = field.depend_on;\n        if (field.beforeOpenFunction) {\n          fs.beforeOpenFunction = field.beforeOpenFunction;\n        }\n        fs.filtersFunction = field.filtersFunction ? field.filtersFunction : Creator.evaluateFilters;\n        if (field.optionsFunction) {\n          fs.optionsFunction = field.optionsFunction;\n        }\n        if (field.reference_to) {\n          if (Meteor.isClient) {\n            if (field.createFunction && _.isFunction(field.createFunction)) {\n              fs.createFunction = field.createFunction;\n            } else {\n              if (_.isString(field.reference_to)) {\n                _ref_obj = Creator.Objects[field.reference_to];\n                if (_ref_obj != null ? (ref1 = _ref_obj.permissions) != null ? ref1.allowCreate : void 0 : void 0) {\n                  fs.autoform.create = true;\n                  fs.createFunction = function(lookup_field) {\n                    return Modal.show(\"CreatorObjectModal\", {\n                      collection: \"Creator.Collections.\" + (Creator.getCollection(field.reference_to)._name),\n                      formId: \"new\" + (field.reference_to.replace('.', '_')),\n                      object_name: \"\" + field.reference_to,\n                      operation: \"insert\",\n                      onSuccess: function(operation, result) {\n                        var object;\n                        object = Creator.getObject(result.object_name);\n                        if (result.object_name === \"objects\") {\n                          return lookup_field.addItems([\n                            {\n                              label: result.value.label,\n                              value: result.value.name,\n                              icon: result.value.icon\n                            }\n                          ], result.value.name);\n                        } else {\n                          return lookup_field.addItems([\n                            {\n                              label: result.value[object.NAME_FIELD_KEY] || result.value.label || result.value.name,\n                              value: result._id\n                            }\n                          ], result._id);\n                        }\n                      }\n                    });\n                  };\n                } else {\n                  fs.autoform.create = false;\n                }\n              }\n            }\n          }\n          if (_.isBoolean(field.create)) {\n            fs.autoform.create = field.create;\n          }\n          if (field.reference_sort) {\n            fs.autoform.optionsSort = field.reference_sort;\n          }\n          if (field.reference_limit) {\n            fs.autoform.optionsLimit = field.reference_limit;\n          }\n          if (field.reference_to_field) {\n            fs.autoform.referenceToField = field.reference_to_field;\n          }\n          if (field.reference_to === \"users\") {\n            fs.autoform.type = \"selectuser\";\n            if (!field.hidden && !field.omit) {\n              if (field.is_company_limited === void 0) {\n                if (Meteor.isClient) {\n                  permissions = obj.permissions;\n                  isUnLimited = permissions != null ? permissions.viewAllRecords : void 0;\n                  if (_.include([\"organizations\", \"users\", \"space_users\"], obj.name)) {\n                    isUnLimited = permissions != null ? permissions.modifyAllRecords : void 0;\n                  }\n                  if (isUnLimited) {\n                    fs.autoform.is_company_limited = false;\n                  } else {\n                    fs.autoform.is_company_limited = true;\n                  }\n                }\n              } else if (_.isFunction(field.is_company_limited)) {\n                if (Meteor.isClient) {\n                  fs.autoform.is_company_limited = field.is_company_limited(obj.permissions);\n                } else {\n                  fs.autoform.is_company_limited = true;\n                }\n              } else {\n                fs.autoform.is_company_limited = field.is_company_limited;\n              }\n            } else {\n              fs.autoform.is_company_limited = field.is_company_limited;\n            }\n          } else if (field.reference_to === \"organizations\") {\n            fs.autoform.type = \"selectorg\";\n            if (!field.hidden && !field.omit) {\n              if (field.is_company_limited === void 0) {\n                if (Meteor.isClient) {\n                  permissions = obj.permissions;\n                  isUnLimited = permissions != null ? permissions.viewAllRecords : void 0;\n                  if (_.include([\"organizations\", \"users\", \"space_users\"], obj.name)) {\n                    isUnLimited = permissions != null ? permissions.modifyAllRecords : void 0;\n                  }\n                  if (isUnLimited) {\n                    fs.autoform.is_company_limited = false;\n                  } else {\n                    fs.autoform.is_company_limited = true;\n                  }\n                }\n              } else if (_.isFunction(field.is_company_limited)) {\n                if (Meteor.isClient) {\n                  fs.autoform.is_company_limited = field.is_company_limited(obj.permissions);\n                } else {\n                  fs.autoform.is_company_limited = true;\n                }\n              } else {\n                fs.autoform.is_company_limited = field.is_company_limited;\n              }\n            } else {\n              fs.autoform.is_company_limited = field.is_company_limited;\n            }\n          } else {\n            if (typeof field.reference_to === \"function\") {\n              _reference_to = field.reference_to();\n            } else {\n              _reference_to = field.reference_to;\n            }\n            if (_.isArray(_reference_to)) {\n              fs.type = Object;\n              fs.blackbox = true;\n              fs.autoform.objectSwitche = true;\n              schema[field_name + \".o\"] = {\n                type: String,\n                autoform: {\n                  omit: true\n                }\n              };\n              schema[field_name + \".ids\"] = {\n                type: [String],\n                autoform: {\n                  omit: true\n                }\n              };\n            } else {\n              _reference_to = [_reference_to];\n            }\n            _object = Creator.Objects[_reference_to[0]];\n            if (_object && _object.enable_tree) {\n              fs.autoform.type = \"selectTree\";\n            } else {\n              fs.autoform.type = \"steedosLookups\";\n              fs.autoform.optionsMethod = field.optionsMethod || \"creator.object_options\";\n              if (Meteor.isClient) {\n                fs.autoform.optionsMethodParams = function() {\n                  return {\n                    space: Session.get(\"spaceId\")\n                  };\n                };\n                fs.autoform.references = [];\n                _reference_to.forEach(function(_reference) {\n                  _object = Creator.Objects[_reference];\n                  if (_object) {\n                    return fs.autoform.references.push({\n                      object: _reference,\n                      label: _object != null ? _object.label : void 0,\n                      icon: _object != null ? _object.icon : void 0,\n                      link: function() {\n                        return \"/app/\" + (Session.get('app_id')) + \"/\" + _reference + \"/view/\";\n                      }\n                    });\n                  } else {\n                    return fs.autoform.references.push({\n                      object: _reference,\n                      link: function() {\n                        return \"/app/\" + (Session.get('app_id')) + \"/\" + _reference + \"/view/\";\n                      }\n                    });\n                  }\n                });\n              }\n            }\n          }\n        } else {\n          fs.autoform.type = \"steedosLookups\";\n          fs.autoform.defaultIcon = field.defaultIcon;\n        }\n      }\n    } else if (field.type === \"select\") {\n      fs.type = String;\n      if (field.multiple) {\n        fs.type = [String];\n        fs.autoform.type = \"steedosLookups\";\n        fs.autoform.showIcon = false;\n        fs.autoform.options = field.options;\n      } else {\n        fs.autoform.type = \"select\";\n        fs.autoform.options = field.options;\n        if (_.has(field, 'firstOption')) {\n          fs.autoform.firstOption = field.firstOption;\n        } else {\n          fs.autoform.firstOption = \"\";\n        }\n      }\n      if (field.data_type && field.data_type !== \"text\") {\n        if ([\"number\", \"currency\", \"percent\"].indexOf(field.data_type) > -1) {\n          fsType = Number;\n          fs.decimal = true;\n        } else if (field.data_type === \"boolean\") {\n          fsType = Boolean;\n        } else {\n          fsType = String;\n        }\n        fs.type = fsType;\n        if (field.multiple) {\n          fs.type = [fsType];\n        }\n        fs.autoform.options = Creator.getSelectOptions(field);\n      }\n    } else if (field.type === \"currency\") {\n      fs.type = Number;\n      fs.autoform.type = \"steedosNumber\";\n      fs.autoform.precision = field.precision || 18;\n      if (field != null ? field.scale : void 0) {\n        fs.autoform.scale = field.scale;\n        fs.decimal = true;\n      } else if ((field != null ? field.scale : void 0) !== 0) {\n        fs.autoform.scale = 2;\n        fs.decimal = true;\n      }\n    } else if (field.type === \"number\") {\n      fs.type = Number;\n      fs.autoform.type = \"steedosNumber\";\n      fs.autoform.precision = field.precision || 18;\n      if (field != null ? field.scale : void 0) {\n        fs.autoform.scale = field.scale;\n        fs.decimal = true;\n      }\n    } else if (field.type === \"boolean\") {\n      fs.type = Boolean;\n      if (field.readonly) {\n        fs.autoform.disabled = true;\n      }\n      fs.autoform.type = \"steedos-boolean-checkbox\";\n    } else if (field.type === \"toggle\") {\n      fs.type = Boolean;\n      if (field.readonly) {\n        fs.autoform.disabled = true;\n      }\n      fs.autoform.type = \"steedos-boolean-toggle\";\n    } else if (field.type === \"reference\") {\n      fs.type = String;\n    } else if (field.type === \"checkbox\") {\n      fs.type = [String];\n      fs.autoform.type = \"select-checkbox\";\n      fs.autoform.options = field.options;\n    } else if (field.type === \"file\") {\n      collectionName = field.collection || \"files\";\n      if (field.multiple) {\n        fs.type = [String];\n        schema[field_name + \".$\"] = {\n          autoform: {\n            type: 'fileUpload',\n            collection: collectionName\n          }\n        };\n      } else {\n        fs.type = String;\n        fs.autoform.type = 'fileUpload';\n        fs.autoform.collection = collectionName;\n      }\n    } else if (field.type === \"filesize\") {\n      fs.type = Number;\n      fs.autoform.type = 'filesize';\n    } else if (field.type === \"Object\" || field.type === \"object\") {\n      fs.type = Object;\n    } else if (field.type === \"grid\" || field.type === \"table\") {\n      fs.type = Array;\n      fs.autoform.editable = true;\n      fs.autoform.type = \"steedosGrid\";\n      schema[field_name + \".$\"] = {\n        type: Object\n      };\n    } else if (field.type === \"image\") {\n      if (field.multiple) {\n        fs.type = [String];\n        schema[field_name + \".$\"] = {\n          autoform: {\n            type: 'fileUpload',\n            collection: 'images',\n            accept: 'image/*'\n          }\n        };\n      } else {\n        fs.type = String;\n        fs.autoform.type = 'fileUpload';\n        fs.autoform.collection = 'images';\n        fs.autoform.accept = 'image/*';\n      }\n    } else if (field.type === \"avatar\") {\n      if (field.multiple) {\n        fs.type = [String];\n        schema[field_name + \".$\"] = {\n          autoform: {\n            type: 'fileUpload',\n            collection: 'avatars',\n            accept: 'image/*'\n          }\n        };\n      } else {\n        fs.type = String;\n        fs.autoform.type = 'fileUpload';\n        fs.autoform.collection = 'avatars';\n        fs.autoform.accept = 'image/*';\n      }\n    } else if (field.type === \"audio\") {\n      if (field.multiple) {\n        fs.type = [String];\n        schema[field_name + \".$\"] = {\n          autoform: {\n            type: 'fileUpload',\n            collection: 'audios',\n            accept: 'audio/*'\n          }\n        };\n      } else {\n        fs.type = String;\n        fs.autoform.type = 'fileUpload';\n        fs.autoform.collection = 'audios';\n        fs.autoform.accept = 'audio/*';\n      }\n    } else if (field.type === \"video\") {\n      if (field.multiple) {\n        fs.type = [String];\n        schema[field_name + \".$\"] = {\n          autoform: {\n            type: 'fileUpload',\n            collection: 'videos',\n            accept: 'video/*'\n          }\n        };\n      } else {\n        fs.type = String;\n        fs.autoform.type = 'fileUpload';\n        fs.autoform.collection = 'videos';\n        fs.autoform.accept = 'video/*';\n      }\n    } else if (field.type === \"location\") {\n      fs.type = Object;\n      fs.autoform.type = \"location\";\n      fs.autoform.system = field.system || \"wgs84\";\n      fs.blackbox = true;\n    } else if (field.type === \"markdown\") {\n      fs.type = String;\n      fs.autoform.type = \"text\";\n    } else if (field.type === 'url') {\n      fs.type = String;\n      fs.autoform.type = 'steedosUrl';\n    } else if (field.type === 'email') {\n      fs.type = String;\n      fs.regEx = SimpleSchema.RegEx.Email;\n      fs.autoform.type = 'steedosEmail';\n    } else if (field.type === 'autonumber') {\n      fs.type = String;\n    } else if (field.type === 'color') {\n      fs.type = String;\n    } else if (field.type === 'formula') {\n      fs = Creator.getObjectSchema({\n        fields: {\n          field: Object.assign({}, field, {\n            type: field.data_type\n          })\n        }\n      })[field.name];\n    } else if (field.type === 'summary') {\n      fs = Creator.getObjectSchema({\n        fields: {\n          field: Object.assign({}, field, {\n            type: field.data_type\n          })\n        }\n      })[field.name];\n    } else if (field.type === 'percent') {\n      fs.type = Number;\n      fs.autoform.type = \"steedosNumber\";\n      fs.autoform.precision = field.precision || 18;\n      if (!_.isNumber(field.scale)) {\n        field.scale = 0;\n      }\n      fs.autoform.scale = field.scale + 2;\n      fs.decimal = true;\n    } else {\n      fs.type = field.type;\n    }\n    if (field.label) {\n      fs.label = field.label;\n    }\n    if (!field.required) {\n      fs.optional = true;\n    }\n    if (!Meteor.isClient) {\n      fs.optional = true;\n    }\n    if (field.unique) {\n      fs.unique = true;\n    }\n    if (field.omit) {\n      fs.autoform.omit = true;\n    }\n    if (field.group) {\n      fs.autoform.group = field.group;\n    }\n    if (field.is_wide) {\n      fs.autoform.is_wide = true;\n    }\n    if (field.hidden) {\n      fs.autoform.type = \"hidden\";\n    }\n    if ((field.type === \"select\") || (field.type === \"lookup\") || (field.type === \"master_detail\")) {\n      if (typeof field.filterable === 'undefined') {\n        field.filterable = true;\n      }\n    }\n    if (field.name === 'name' || field.is_name) {\n      if (typeof field.searchable === 'undefined') {\n        field.searchable = true;\n      }\n    }\n    if (autoform_type) {\n      fs.autoform.type = autoform_type;\n    }\n    if (field.defaultValue) {\n      if (Meteor.isClient && Creator.Formular.checkFormula(field.defaultValue)) {\n        fs.autoform.defaultValue = function() {\n          return Creator.Formular.run(field.defaultValue, {\n            userId: Meteor.userId(),\n            spaceId: Session.get(\"spaceId\"),\n            now: new Date()\n          });\n        };\n      } else {\n        fs.autoform.defaultValue = field.defaultValue;\n      }\n    }\n    if (field.readonly) {\n      fs.autoform.readonly = true;\n    }\n    if (field.disabled) {\n      fs.autoform.disabled = true;\n    }\n    if (field.inlineHelpText) {\n      fs.autoform.inlineHelpText = field.inlineHelpText;\n    }\n    if (field.blackbox) {\n      fs.blackbox = true;\n    }\n    if (_.has(field, 'min')) {\n      fs.min = field.min;\n    }\n    if (_.has(field, 'max')) {\n      fs.max = field.max;\n    }\n    if (Meteor.isProduction) {\n      if (field.index) {\n        fs.index = field.index;\n      } else if (field.sortable) {\n        fs.index = true;\n      }\n    }\n    return schema[field_name] = fs;\n  });\n  return schema;\n};\n\nCreator.getFieldDisplayValue = function(object_name, field_name, field_value) {\n  var field, html, object;\n  html = field_value;\n  object = Creator.getObject(object_name);\n  if (!object) {\n    return \"\";\n  }\n  field = object.fields(field_name);\n  if (!field) {\n    return \"\";\n  }\n  if (field.type === \"datetime\") {\n    html = moment(this.val).format('YYYY-MM-DD H:mm');\n  } else if (field.type === \"date\") {\n    html = moment(this.val).format('YYYY-MM-DD');\n  }\n  return html;\n};\n\nCreator.checkFieldTypeSupportBetweenQuery = function(field_type) {\n  return [\"date\", \"datetime\", \"time\", \"currency\", \"number\"].includes(field_type);\n};\n\nCreator.pushBetweenBuiltinOptionals = function(field_type, operations) {\n  var builtinValues;\n  builtinValues = Creator.getBetweenBuiltinValues(field_type);\n  if (builtinValues) {\n    return _.forEach(builtinValues, function(builtinItem, key) {\n      return operations.push({\n        label: builtinItem.label,\n        value: key\n      });\n    });\n  }\n};\n\nCreator.getBetweenBuiltinValues = function(field_type, is_check_only) {\n  if ([\"date\", \"datetime\"].includes(field_type)) {\n    return Creator.getBetweenTimeBuiltinValues(is_check_only, field_type);\n  }\n};\n\nCreator.getBetweenBuiltinValueItem = function(field_type, key) {\n  if ([\"date\", \"datetime\"].includes(field_type)) {\n    return Creator.getBetweenTimeBuiltinValueItem(field_type, key);\n  }\n};\n\nCreator.getBetweenBuiltinOperation = function(field_type, value) {\n  var betweenBuiltinValues, result;\n  if (!_.isString(value)) {\n    return;\n  }\n  betweenBuiltinValues = Creator.getBetweenBuiltinValues(field_type);\n  if (!betweenBuiltinValues) {\n    return;\n  }\n  result = null;\n  _.each(betweenBuiltinValues, function(item, operation) {\n    if (item.key === value) {\n      return result = operation;\n    }\n  });\n  return result;\n};\n\nCreator.getBetweenTimeBuiltinValues = function(is_check_only, field_type) {\n  return {\n    \"between_time_last_year\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_year\"),\n    \"between_time_this_year\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_year\"),\n    \"between_time_next_year\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_year\"),\n    \"between_time_last_quarter\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_quarter\"),\n    \"between_time_this_quarter\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_quarter\"),\n    \"between_time_next_quarter\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_quarter\"),\n    \"between_time_last_month\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_month\"),\n    \"between_time_this_month\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_month\"),\n    \"between_time_next_month\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_month\"),\n    \"between_time_last_week\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_week\"),\n    \"between_time_this_week\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_week\"),\n    \"between_time_next_week\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_week\"),\n    \"between_time_yestday\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"yestday\"),\n    \"between_time_today\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"today\"),\n    \"between_time_tomorrow\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"tomorrow\"),\n    \"between_time_last_7_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_7_days\"),\n    \"between_time_last_30_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_30_days\"),\n    \"between_time_last_60_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_60_days\"),\n    \"between_time_last_90_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_90_days\"),\n    \"between_time_last_120_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_120_days\"),\n    \"between_time_next_7_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_7_days\"),\n    \"between_time_next_30_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_30_days\"),\n    \"between_time_next_60_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_60_days\"),\n    \"between_time_next_90_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_90_days\"),\n    \"between_time_next_120_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_120_days\")\n  };\n};\n\nCreator.getQuarterStartMonth = function(month) {\n  if (!month) {\n    month = new Date().getMonth();\n  }\n  if (month < 3) {\n    return 0;\n  } else if (month < 6) {\n    return 3;\n  } else if (month < 9) {\n    return 6;\n  }\n  return 9;\n};\n\nCreator.getLastQuarterFirstDay = function(year, month) {\n  if (!year) {\n    year = new Date().getFullYear();\n  }\n  if (!month) {\n    month = new Date().getMonth();\n  }\n  if (month < 3) {\n    year--;\n    month = 9;\n  } else if (month < 6) {\n    month = 0;\n  } else if (month < 9) {\n    month = 3;\n  } else {\n    month = 6;\n  }\n  return new Date(year, month, 1);\n};\n\nCreator.getNextQuarterFirstDay = function(year, month) {\n  if (!year) {\n    year = new Date().getFullYear();\n  }\n  if (!month) {\n    month = new Date().getMonth();\n  }\n  if (month < 3) {\n    month = 3;\n  } else if (month < 6) {\n    month = 6;\n  } else if (month < 9) {\n    month = 9;\n  } else {\n    year++;\n    month = 0;\n  }\n  return new Date(year, month, 1);\n};\n\nCreator.getMonthDays = function(year, month) {\n  var days, endDate, millisecond, startDate;\n  if (month === 11) {\n    return 31;\n  }\n  millisecond = 1000 * 60 * 60 * 24;\n  startDate = new Date(year, month, 1);\n  endDate = new Date(year, month + 1, 1);\n  days = (endDate - startDate) / millisecond;\n  return days;\n};\n\nCreator.getLastMonthFirstDay = function(year, month) {\n  if (!year) {\n    year = new Date().getFullYear();\n  }\n  if (!month) {\n    month = new Date().getMonth();\n  }\n  if (month === 0) {\n    month = 11;\n    year--;\n    return new Date(year, month, 1);\n  }\n  month--;\n  return new Date(year, month, 1);\n};\n\nCreator.getBetweenTimeBuiltinValueItem = function(field_type, key) {\n  var currentMonth, currentYear, endValue, firstDay, label, lastDay, lastMonday, lastMonthFinalDay, lastMonthFirstDay, lastQuarterEndDay, lastQuarterStartDay, lastSunday, last_120_days, last_30_days, last_60_days, last_7_days, last_90_days, millisecond, minusDay, monday, month, nextMonday, nextMonthFinalDay, nextMonthFirstDay, nextQuarterEndDay, nextQuarterStartDay, nextSunday, nextYear, next_120_days, next_30_days, next_60_days, next_7_days, next_90_days, now, previousYear, startValue, strEndDay, strFirstDay, strLastDay, strMonday, strStartDay, strSunday, strToday, strTomorrow, strYestday, sunday, thisQuarterEndDay, thisQuarterStartDay, tomorrow, values, week, year, yestday;\n  now = new Date();\n  millisecond = 1000 * 60 * 60 * 24;\n  yestday = new Date(now.getTime() - millisecond);\n  tomorrow = new Date(now.getTime() + millisecond);\n  week = now.getDay();\n  minusDay = week !== 0 ? week - 1 : 6;\n  monday = new Date(now.getTime() - (minusDay * millisecond));\n  sunday = new Date(monday.getTime() + (6 * millisecond));\n  lastSunday = new Date(monday.getTime() - millisecond);\n  lastMonday = new Date(lastSunday.getTime() - (millisecond * 6));\n  nextMonday = new Date(sunday.getTime() + millisecond);\n  nextSunday = new Date(nextMonday.getTime() + (millisecond * 6));\n  currentYear = now.getFullYear();\n  previousYear = currentYear - 1;\n  nextYear = currentYear + 1;\n  currentMonth = now.getMonth();\n  year = now.getFullYear();\n  month = now.getMonth();\n  firstDay = new Date(currentYear, currentMonth, 1);\n  if (currentMonth === 11) {\n    year++;\n    month++;\n  } else {\n    month++;\n  }\n  nextMonthFirstDay = new Date(year, month, 1);\n  nextMonthFinalDay = new Date(year, month, Creator.getMonthDays(year, month));\n  lastDay = new Date(nextMonthFirstDay.getTime() - millisecond);\n  lastMonthFirstDay = Creator.getLastMonthFirstDay(currentYear, currentMonth);\n  lastMonthFinalDay = new Date(firstDay.getTime() - millisecond);\n  thisQuarterStartDay = new Date(currentYear, Creator.getQuarterStartMonth(currentMonth), 1);\n  thisQuarterEndDay = new Date(currentYear, Creator.getQuarterStartMonth(currentMonth) + 2, Creator.getMonthDays(currentYear, Creator.getQuarterStartMonth(currentMonth) + 2));\n  lastQuarterStartDay = Creator.getLastQuarterFirstDay(currentYear, currentMonth);\n  lastQuarterEndDay = new Date(lastQuarterStartDay.getFullYear(), lastQuarterStartDay.getMonth() + 2, Creator.getMonthDays(lastQuarterStartDay.getFullYear(), lastQuarterStartDay.getMonth() + 2));\n  nextQuarterStartDay = Creator.getNextQuarterFirstDay(currentYear, currentMonth);\n  nextQuarterEndDay = new Date(nextQuarterStartDay.getFullYear(), nextQuarterStartDay.getMonth() + 2, Creator.getMonthDays(nextQuarterStartDay.getFullYear(), nextQuarterStartDay.getMonth() + 2));\n  last_7_days = new Date(now.getTime() - (6 * millisecond));\n  last_30_days = new Date(now.getTime() - (29 * millisecond));\n  last_60_days = new Date(now.getTime() - (59 * millisecond));\n  last_90_days = new Date(now.getTime() - (89 * millisecond));\n  last_120_days = new Date(now.getTime() - (119 * millisecond));\n  next_7_days = new Date(now.getTime() + (6 * millisecond));\n  next_30_days = new Date(now.getTime() + (29 * millisecond));\n  next_60_days = new Date(now.getTime() + (59 * millisecond));\n  next_90_days = new Date(now.getTime() + (89 * millisecond));\n  next_120_days = new Date(now.getTime() + (119 * millisecond));\n  switch (key) {\n    case \"last_year\":\n      label = t(\"creator_filter_operation_between_last_year\");\n      startValue = new Date(previousYear + \"-01-01T00:00:00Z\");\n      endValue = new Date(previousYear + \"-12-31T23:59:59Z\");\n      break;\n    case \"this_year\":\n      label = t(\"creator_filter_operation_between_this_year\");\n      startValue = new Date(currentYear + \"-01-01T00:00:00Z\");\n      endValue = new Date(currentYear + \"-12-31T23:59:59Z\");\n      break;\n    case \"next_year\":\n      label = t(\"creator_filter_operation_between_next_year\");\n      startValue = new Date(nextYear + \"-01-01T00:00:00Z\");\n      endValue = new Date(nextYear + \"-12-31T23:59:59Z\");\n      break;\n    case \"last_quarter\":\n      strFirstDay = moment(lastQuarterStartDay).format(\"YYYY-MM-DD\");\n      strLastDay = moment(lastQuarterEndDay).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_last_quarter\");\n      startValue = new Date(strFirstDay + \"T00:00:00Z\");\n      endValue = new Date(strLastDay + \"T23:59:59Z\");\n      break;\n    case \"this_quarter\":\n      strFirstDay = moment(thisQuarterStartDay).format(\"YYYY-MM-DD\");\n      strLastDay = moment(thisQuarterEndDay).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_this_quarter\");\n      startValue = new Date(strFirstDay + \"T00:00:00Z\");\n      endValue = new Date(strLastDay + \"T23:59:59Z\");\n      break;\n    case \"next_quarter\":\n      strFirstDay = moment(nextQuarterStartDay).format(\"YYYY-MM-DD\");\n      strLastDay = moment(nextQuarterEndDay).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_next_quarter\");\n      startValue = new Date(strFirstDay + \"T00:00:00Z\");\n      endValue = new Date(strLastDay + \"T23:59:59Z\");\n      break;\n    case \"last_month\":\n      strFirstDay = moment(lastMonthFirstDay).format(\"YYYY-MM-DD\");\n      strLastDay = moment(lastMonthFinalDay).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_last_month\");\n      startValue = new Date(strFirstDay + \"T00:00:00Z\");\n      endValue = new Date(strLastDay + \"T23:59:59Z\");\n      break;\n    case \"this_month\":\n      strFirstDay = moment(firstDay).format(\"YYYY-MM-DD\");\n      strLastDay = moment(lastDay).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_this_month\");\n      startValue = new Date(strFirstDay + \"T00:00:00Z\");\n      endValue = new Date(strLastDay + \"T23:59:59Z\");\n      break;\n    case \"next_month\":\n      strFirstDay = moment(nextMonthFirstDay).format(\"YYYY-MM-DD\");\n      strLastDay = moment(nextMonthFinalDay).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_next_month\");\n      startValue = new Date(strFirstDay + \"T00:00:00Z\");\n      endValue = new Date(strLastDay + \"T23:59:59Z\");\n      break;\n    case \"last_week\":\n      strMonday = moment(lastMonday).format(\"YYYY-MM-DD\");\n      strSunday = moment(lastSunday).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_last_week\");\n      startValue = new Date(strMonday + \"T00:00:00Z\");\n      endValue = new Date(strSunday + \"T23:59:59Z\");\n      break;\n    case \"this_week\":\n      strMonday = moment(monday).format(\"YYYY-MM-DD\");\n      strSunday = moment(sunday).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_this_week\");\n      startValue = new Date(strMonday + \"T00:00:00Z\");\n      endValue = new Date(strSunday + \"T23:59:59Z\");\n      break;\n    case \"next_week\":\n      strMonday = moment(nextMonday).format(\"YYYY-MM-DD\");\n      strSunday = moment(nextSunday).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_next_week\");\n      startValue = new Date(strMonday + \"T00:00:00Z\");\n      endValue = new Date(strSunday + \"T23:59:59Z\");\n      break;\n    case \"yestday\":\n      strYestday = moment(yestday).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_yestday\");\n      startValue = new Date(strYestday + \"T00:00:00Z\");\n      endValue = new Date(strYestday + \"T23:59:59Z\");\n      break;\n    case \"today\":\n      strToday = moment(now).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_today\");\n      startValue = new Date(strToday + \"T00:00:00Z\");\n      endValue = new Date(strToday + \"T23:59:59Z\");\n      break;\n    case \"tomorrow\":\n      strTomorrow = moment(tomorrow).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_tomorrow\");\n      startValue = new Date(strTomorrow + \"T00:00:00Z\");\n      endValue = new Date(strTomorrow + \"T23:59:59Z\");\n      break;\n    case \"last_7_days\":\n      strStartDay = moment(last_7_days).format(\"YYYY-MM-DD\");\n      strEndDay = moment(now).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_last_7_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n      break;\n    case \"last_30_days\":\n      strStartDay = moment(last_30_days).format(\"YYYY-MM-DD\");\n      strEndDay = moment(now).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_last_30_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n      break;\n    case \"last_60_days\":\n      strStartDay = moment(last_60_days).format(\"YYYY-MM-DD\");\n      strEndDay = moment(now).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_last_60_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n      break;\n    case \"last_90_days\":\n      strStartDay = moment(last_90_days).format(\"YYYY-MM-DD\");\n      strEndDay = moment(now).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_last_90_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n      break;\n    case \"last_120_days\":\n      strStartDay = moment(last_120_days).format(\"YYYY-MM-DD\");\n      strEndDay = moment(now).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_last_120_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n      break;\n    case \"next_7_days\":\n      strStartDay = moment(now).format(\"YYYY-MM-DD\");\n      strEndDay = moment(next_7_days).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_next_7_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n      break;\n    case \"next_30_days\":\n      strStartDay = moment(now).format(\"YYYY-MM-DD\");\n      strEndDay = moment(next_30_days).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_next_30_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n      break;\n    case \"next_60_days\":\n      strStartDay = moment(now).format(\"YYYY-MM-DD\");\n      strEndDay = moment(next_60_days).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_next_60_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n      break;\n    case \"next_90_days\":\n      strStartDay = moment(now).format(\"YYYY-MM-DD\");\n      strEndDay = moment(next_90_days).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_next_90_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n      break;\n    case \"next_120_days\":\n      strStartDay = moment(now).format(\"YYYY-MM-DD\");\n      strEndDay = moment(next_120_days).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_next_120_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n  }\n  values = [startValue, endValue];\n  if (field_type === \"datetime\") {\n    _.forEach(values, function(fv) {\n      if (fv) {\n        return fv.setHours(fv.getHours() + fv.getTimezoneOffset() / 60);\n      }\n    });\n  }\n  return {\n    label: label,\n    key: key,\n    values: values\n  };\n};\n\nCreator.getFieldDefaultOperation = function(field_type) {\n  if (field_type && Creator.checkFieldTypeSupportBetweenQuery(field_type)) {\n    return 'between';\n  } else if ([\"textarea\", \"text\", \"code\"].includes(field_type)) {\n    return 'contains';\n  } else {\n    return \"=\";\n  }\n};\n\nCreator.getFieldOperation = function(field_type) {\n  var operations, optionals;\n  optionals = {\n    equal: {\n      label: t(\"creator_filter_operation_equal\"),\n      value: \"=\"\n    },\n    unequal: {\n      label: t(\"creator_filter_operation_unequal\"),\n      value: \"<>\"\n    },\n    less_than: {\n      label: t(\"creator_filter_operation_less_than\"),\n      value: \"<\"\n    },\n    greater_than: {\n      label: t(\"creator_filter_operation_greater_than\"),\n      value: \">\"\n    },\n    less_or_equal: {\n      label: t(\"creator_filter_operation_less_or_equal\"),\n      value: \"<=\"\n    },\n    greater_or_equal: {\n      label: t(\"creator_filter_operation_greater_or_equal\"),\n      value: \">=\"\n    },\n    contains: {\n      label: t(\"creator_filter_operation_contains\"),\n      value: \"contains\"\n    },\n    not_contain: {\n      label: t(\"creator_filter_operation_does_not_contain\"),\n      value: \"notcontains\"\n    },\n    starts_with: {\n      label: t(\"creator_filter_operation_starts_with\"),\n      value: \"startswith\"\n    },\n    between: {\n      label: t(\"creator_filter_operation_between\"),\n      value: \"between\"\n    }\n  };\n  if (field_type === void 0) {\n    return _.values(optionals);\n  }\n  operations = [];\n  if (Creator.checkFieldTypeSupportBetweenQuery(field_type)) {\n    operations.push(optionals.between);\n    Creator.pushBetweenBuiltinOptionals(field_type, operations);\n  } else if (field_type === \"text\" || field_type === \"textarea\" || field_type === \"html\" || field_type === \"code\") {\n    operations.push(optionals.contains);\n  } else if (field_type === \"lookup\" || field_type === \"master_detail\" || field_type === \"select\") {\n    operations.push(optionals.equal, optionals.unequal);\n  } else if (field_type === \"currency\" || field_type === \"number\") {\n    operations.push(optionals.equal, optionals.unequal, optionals.less_than, optionals.greater_than, optionals.less_or_equal, optionals.greater_or_equal);\n  } else if (field_type === \"boolean\") {\n    operations.push(optionals.equal, optionals.unequal);\n  } else if (field_type === \"checkbox\") {\n    operations.push(optionals.equal, optionals.unequal);\n  } else if (field_type === \"[text]\") {\n    operations.push(optionals.equal, optionals.unequal);\n  } else {\n    operations.push(optionals.equal, optionals.unequal);\n  }\n  return operations;\n};\n\n\n/*\n    先按照有排序号的小的在前，大的在后\n    再将没有排序号的显示在\n */\n\nCreator.getObjectFieldsName = function(object_name) {\n  var fields, fieldsArr, fieldsName, ref;\n  fields = (ref = Creator.getObject(object_name)) != null ? ref.fields : void 0;\n  fieldsArr = [];\n  _.each(fields, function(field) {\n    return fieldsArr.push({\n      name: field.name,\n      sort_no: field.sort_no\n    });\n  });\n  fieldsName = [];\n  _.each(_.sortBy(fieldsArr, \"sort_no\"), function(field) {\n    return fieldsName.push(field.name);\n  });\n  return fieldsName;\n};\n","Creator._trigger_hooks = {}\n\ninitTrigger = (object_name, trigger)->\n\ttry\n\t\tcollection = Creator.getCollection(object_name)\n\t\tif !trigger.todo\n\t\t\treturn\n\t\ttodoWrapper = ()->\n\t\t\t  this.object_name = object_name\n\t\t\t  return trigger.todo.apply(this, arguments)\n\t\tif trigger.when == \"before.insert\"\n\t\t\t  return collection?.before?.insert(todoWrapper)\n\t\t  else if trigger.when == \"before.update\"\n\t\t\t  return collection?.before?.update(todoWrapper)\n\t\t  else if trigger.when == \"before.remove\"\n\t\t\t  return collection?.before?.remove(todoWrapper)\n\t\t  else if trigger.when == \"after.insert\"\n\t\t\t  return collection?.after?.insert(todoWrapper)\n\t\t  else if trigger.when == \"after.update\"\n\t\t\t  return collection?.after?.update(todoWrapper)\n\t\t  else if trigger.when == \"after.remove\"\n\t\t\t  return collection?.after?.remove(todoWrapper)\n\tcatch error\n\t\tconsole.error('initTrigger error', error)\n\ncleanTrigger = (object_name)->\n\t###\n    \t由于collection-hooks package 的remove函数是使用下标删除对象的，所以此处反转hooks集合后，再删除\n    \t因为一个数组元素删除后，其他元素的下标会发生变化\n\t###\n    #TODO 由于collection-hooks package 的remove函数bug\n\tCreator._trigger_hooks[object_name]?.reverse().forEach (_hook)->\n\t\t_hook.remove()\n\nCreator.initTriggers = (object_name)->\n#\tconsole.log('Creator.initTriggers object_name', object_name)\n\tobj = Creator.getObject(object_name)\n\n\tcleanTrigger(object_name)\n\n\tCreator._trigger_hooks[object_name] = []\n\n\t_.each obj.triggers, (trigger, trigger_name)->\n\t\tif Meteor.isServer and trigger.on == \"server\" and trigger.todo and trigger.when\n\t\t\t_trigger_hook = initTrigger object_name, trigger\n\t\t\tif _trigger_hook\n\t\t\t\tCreator._trigger_hooks[object_name].push(_trigger_hook)\n\t\tif Meteor.isClient and trigger.on == \"client\" and trigger.todo and trigger.when\n\t\t\t_trigger_hook = initTrigger object_name, trigger\n\t\t\tCreator._trigger_hooks[object_name].push(_trigger_hook)","var cleanTrigger, initTrigger;\n\nCreator._trigger_hooks = {};\n\ninitTrigger = function(object_name, trigger) {\n  var collection, error, ref, ref1, ref2, ref3, ref4, ref5, todoWrapper;\n  try {\n    collection = Creator.getCollection(object_name);\n    if (!trigger.todo) {\n      return;\n    }\n    todoWrapper = function() {\n      this.object_name = object_name;\n      return trigger.todo.apply(this, arguments);\n    };\n    if (trigger.when === \"before.insert\") {\n      return collection != null ? (ref = collection.before) != null ? ref.insert(todoWrapper) : void 0 : void 0;\n    } else if (trigger.when === \"before.update\") {\n      return collection != null ? (ref1 = collection.before) != null ? ref1.update(todoWrapper) : void 0 : void 0;\n    } else if (trigger.when === \"before.remove\") {\n      return collection != null ? (ref2 = collection.before) != null ? ref2.remove(todoWrapper) : void 0 : void 0;\n    } else if (trigger.when === \"after.insert\") {\n      return collection != null ? (ref3 = collection.after) != null ? ref3.insert(todoWrapper) : void 0 : void 0;\n    } else if (trigger.when === \"after.update\") {\n      return collection != null ? (ref4 = collection.after) != null ? ref4.update(todoWrapper) : void 0 : void 0;\n    } else if (trigger.when === \"after.remove\") {\n      return collection != null ? (ref5 = collection.after) != null ? ref5.remove(todoWrapper) : void 0 : void 0;\n    }\n  } catch (error1) {\n    error = error1;\n    return console.error('initTrigger error', error);\n  }\n};\n\ncleanTrigger = function(object_name) {\n\n  /*\n     \t由于collection-hooks package 的remove函数是使用下标删除对象的，所以此处反转hooks集合后，再删除\n     \t因为一个数组元素删除后，其他元素的下标会发生变化\n   */\n  var ref;\n  return (ref = Creator._trigger_hooks[object_name]) != null ? ref.reverse().forEach(function(_hook) {\n    return _hook.remove();\n  }) : void 0;\n};\n\nCreator.initTriggers = function(object_name) {\n  var obj;\n  obj = Creator.getObject(object_name);\n  cleanTrigger(object_name);\n  Creator._trigger_hooks[object_name] = [];\n  return _.each(obj.triggers, function(trigger, trigger_name) {\n    var _trigger_hook;\n    if (Meteor.isServer && trigger.on === \"server\" && trigger.todo && trigger.when) {\n      _trigger_hook = initTrigger(object_name, trigger);\n      if (_trigger_hook) {\n        Creator._trigger_hooks[object_name].push(_trigger_hook);\n      }\n    }\n    if (Meteor.isClient && trigger.on === \"client\" && trigger.todo && trigger.when) {\n      _trigger_hook = initTrigger(object_name, trigger);\n      return Creator._trigger_hooks[object_name].push(_trigger_hook);\n    }\n  });\n};\n","clone = require('clone')\n\nbaseBooleanPermissionPropNames = [\"allowCreate\", \"allowDelete\", \"allowEdit\", \"allowRead\", \"modifyAllRecords\", \"viewAllRecords\", \"modifyCompanyRecords\", \"viewCompanyRecords\", \n\t\"allowReadFiles\", \"allowEditFiles\", \"allowCreateFiles\", \"allowDeleteFiles\", \"viewAllFiles\", \"modifyAllFiles\"] \notherPermissionPropNames = [\"disabled_list_views\", \"disabled_actions\", \"unreadable_fields\", \"uneditable_fields\", \"unrelated_objects\", \"uneditable_related_list\"]\npermissionPropNames = _.union baseBooleanPermissionPropNames, otherPermissionPropNames\n\nCreator.getPermissions = (object_name, spaceId, userId)->\n\tif Meteor.isClient\n\t\tif !object_name\n\t\t\tobject_name = Session.get(\"object_name\")\n\t\tobj = Creator.getObject(object_name)\n\t\tif !obj\n\t\t\treturn\n\t\treturn obj.permissions.get()\n\telse if Meteor.isServer\n\t\tCreator.getObjectPermissions(spaceId, userId, object_name)\n\nCreator.getRecordPermissions = (object_name, record, userId, spaceId)->\n\tif !object_name and Meteor.isClient\n\t\tobject_name = Session.get(\"object_name\")\n\n\tif !spaceId and Meteor.isClient\n\t\tspaceId = Session.get(\"spaceId\")\n\t\n\t# 附件权限不再与其父记录编辑配置关联\n\t# if record and object_name == \"cms_files\" and Meteor.isClient\n\t# \t# 如果是cms_files附件，则权限取其父记录权限\n\t# \tif object_name == Session.get('object_name')\n\t# \t\t# 当前处于cms_files附件详细界面\n\t# \t\tobject_name = record.parent['reference_to._o'];\n\t# \t\trecord_id = record.parent._id;\n\t# \telse \n\t# \t\t# 当前处于cms_files附件的父记录界面\n\t# \t\tobject_name = Session.get('object_name');\n\t# \t\trecord_id = Session.get(\"record_id\");\n\t# \tobject_fields_keys = _.keys(Creator.getObject(object_name, spaceId)?.fields or {}) || [];\n\t# \tselect = _.intersection(object_fields_keys, ['owner', 'company_id', 'company_ids', 'locked']) || [];\n\t# \tif select.length > 0\n\t# \t\trecord = Creator.getObjectRecord(object_name, record_id, select.join(','));\n\t# \telse\n\t# \t\trecord = null;\n\n\tpermissions = _.clone(Creator.getPermissions(object_name, spaceId, userId))\n\n\tif record\n\t\tif !_.isEmpty(record.record_permissions)\n\t\t\treturn record.record_permissions\n\n\t\tisOwner = record.owner == userId || record.owner?._id == userId\n\n\t\tif object_name == \"cms_files\"\n\t\t\t# 附件的查看所有修改所有权限与附件对象的viewAllRecords、modifyAllRecords无关，只与其主表记录的viewAllFiles和modifyAllFiles有关\n\t\t\t# 如果是cms_files附件，则权限需要额外考虑其父对象上关于附件的权限配置\n\t\t\tmasterObjectName = record.parent['reference_to._o'];\n\t\t\tmasterRecordPerm = Creator.getPermissions(masterObjectName, spaceId, userId)\n\t\t\tpermissions.allowCreate = permissions.allowCreate && masterRecordPerm.allowCreateFiles\n\t\t\tpermissions.allowEdit = permissions.allowEdit && masterRecordPerm.allowEditFiles\n\t\t\tpermissions.allowDelete = permissions.allowDelete && masterRecordPerm.allowDeleteFiles\n\t\t\tif !masterRecordPerm.modifyAllFiles and !isOwner\n\t\t\t\tpermissions.allowEdit = false\n\t\t\t\tpermissions.allowDelete = false\n\t\t\tpermissions.allowRead = permissions.allowRead && masterRecordPerm.allowReadFiles\n\t\t\tif !masterRecordPerm.viewAllFiles and !isOwner\n\t\t\t\tpermissions.allowRead = false\n\t\telse\n\t\t\tif Meteor.isClient\n\t\t\t\tuser_company_ids = Steedos.getUserCompanyIds()\n\t\t\telse\n\t\t\t\tuser_company_ids = Creator.getUserCompanyIds(userId, spaceId)\n\t\t\trecord_company_id = record?.company_id\n\t\t\tif record_company_id and _.isObject(record_company_id) and record_company_id._id\n\t\t\t\t# 因record_company_id是lookup类型，有可能dx控件会把它映射转为对应的object，所以这里取出其_id值\n\t\t\t\trecord_company_id = record_company_id._id\n\t\t\trecord_company_ids = record?.company_ids\n\t\t\tif record_company_ids and record_company_ids.length and _.isObject(record_company_ids[0])\n\t\t\t\t# 因record_company_ids是lookup类型，有可能dx控件会把它映射转为对应的[object]，所以这里取出其_id值\n\t\t\t\trecord_company_ids = record_company_ids.map((n)-> n._id)\n\t\t\trecord_company_ids = _.union(record_company_ids, [record_company_id])\n\t\t\tif !permissions.modifyAllRecords and !isOwner and !permissions.modifyCompanyRecords\n\t\t\t\tpermissions.allowEdit = false\n\t\t\t\tpermissions.allowDelete = false\n\t\t\telse if !permissions.modifyAllRecords and permissions.modifyCompanyRecords\n\t\t\t\tif record_company_ids and record_company_ids.length\n\t\t\t\t\tif user_company_ids and user_company_ids.length\n\t\t\t\t\t\tif !_.intersection(user_company_ids, record_company_ids).length\n\t\t\t\t\t\t\t# 记录的company_id/company_ids属性不在当前用户user_company_ids范围内时，认为无权修改\n\t\t\t\t\t\t\tpermissions.allowEdit = false\n\t\t\t\t\t\t\tpermissions.allowDelete = false\n\t\t\t\t\telse\n\t\t\t\t\t\t# 记录有company_id/company_ids属性，但是当前用户user_company_ids为空时，认为无权修改\n\t\t\t\t\t\tpermissions.allowEdit = false\n\t\t\t\t\t\tpermissions.allowDelete = false\n\t\t\t\n\t\t\tif record.locked and !permissions.modifyAllRecords\n\t\t\t\tpermissions.allowEdit = false\n\t\t\t\tpermissions.allowDelete = false\n\n\t\t\tif !permissions.viewAllRecords and !isOwner and !permissions.viewCompanyRecords\n\t\t\t\tpermissions.allowRead = false\n\t\t\telse if !permissions.viewAllRecords and permissions.viewCompanyRecords\n\t\t\t\tif record_company_ids and record_company_ids.length\n\t\t\t\t\tif user_company_ids and user_company_ids.length\n\t\t\t\t\t\tif !_.intersection(user_company_ids, record_company_ids).length\n\t\t\t\t\t\t\t# 记录的company_id/company_ids属性不在当前用户user_company_ids范围内时，认为无权查看\n\t\t\t\t\t\t\tpermissions.allowRead = false\n\t\t\t\t\telse\n\t\t\t\t\t\t# 记录有company_id属性，但是当前用户user_company_ids为空时，认为无权查看\n\t\t\t\t\t\tpermissions.allowRead = false\n\t\n\treturn permissions\n\n\n# currentObjectName：当前主对象\n# relatedListItem：Creator.getRelatedList(Session.get(\"object_name\"), Session.get(\"record_id\"))中取related_object_name对应的值\n# currentRecord当前主对象的详细记录\nif Meteor.isClient\n\tCreator.getRecordRelatedListPermissions = (currentObjectName, relatedListItem, currentRecord, userId, spaceId)->\n\t\tif !currentObjectName and Meteor.isClient\n\t\t\tcurrentObjectName = Session.get(\"object_name\")\n\n\t\tif !relatedListItem\n\t\t\tconsole.error(\"relatedListItem must not be empty for the function Creator.getRecordRelatedListPermissions\");\n\t\t\treturn {}\n\n\t\tif !currentRecord and Meteor.isClient\n\t\t\tcurrentRecord = Creator.getObjectRecord()\n\n\t\tif !userId and Meteor.isClient\n\t\t\tuserId = Meteor.userId()\n\n\t\tif !spaceId and Meteor.isClient\n\t\t\tspaceId = Session.get(\"spaceId\")\n\n\t\tmasterRecordPerm = Creator.getRecordPermissions(currentObjectName, currentRecord, userId, spaceId)\n\t\trelatedObjectPermissions = Creator.getPermissions(relatedListItem.object_name)\n\t\tresult = _.clone relatedObjectPermissions\n\n\t\tif relatedListItem.is_file\n\t\t\tresult.allowCreate = relatedObjectPermissions.allowCreate && masterRecordPerm.allowCreateFiles\n\t\t\tresult.allowEdit = relatedObjectPermissions.allowEdit && masterRecordPerm.allowEditFiles\n\t\telse\n\t\t\twrite_requires_master_read = relatedListItem.write_requires_master_read || false\n\t\t\tmasterAllow = false\n\t\t\tif write_requires_master_read == true\n\t\t\t\tmasterAllow = masterRecordPerm.allowRead\n\t\t\telse if write_requires_master_read == false\n\t\t\t\tmasterAllow = masterRecordPerm.allowEdit\n\n\t\t\tuneditable_related_list = Creator.getRecordSafeRelatedList(currentRecord, currentObjectName)\n\t\t\tisRelateObjectUneditable = uneditable_related_list.indexOf(relatedListItem.object_name) > -1\n\n\t\t\tresult.allowCreate = masterAllow && relatedObjectPermissions.allowCreate && !isRelateObjectUneditable\n\t\t\tresult.allowEdit = masterAllow && relatedObjectPermissions.allowEdit && !isRelateObjectUneditable\n\t\treturn result\n\nif Meteor.isServer\n\n\tCreator.getAllPermissions = (spaceId, userId) ->\n\t\tpermissions =\n\t\t\tobjects: {}\n\t\t\tassigned_apps: []\n\t\t###\n\t\t权限集说明:\n\t\t内置权限集-admin,user,member,guest,workflow_admin,organization_admin\n\t\t自定义权限集-数据库中新建的除内置权限集以外的其他权限集\n\t\t特定用户集合权限集（即users属性不可配置）-admin,user,member,guest\n\t\t可配置用户集合权限集（即users属性可配置）-workflow_admin,organization_admin以及自定义权限集\n\t\t###\n\n\t\tisSpaceAdmin = false\n\t\tspaceUser = null\n\t\tif userId\n\t\t\tisSpaceAdmin = Creator.isSpaceAdmin(spaceId, userId)\n\t\t\tspaceUser = Creator.getCollection(\"space_users\").findOne({ space: spaceId, user: userId }, { fields: { profile: 1 } })\n\n\t\tpsetsAdmin = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'admin'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tpsetsUser = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'user'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tpsetsMember = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'member'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tpsetsGuest = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'guest'}, {fields:{_id:1, assigned_apps:1}}) || null\n\n\t\tpsetsSupplier = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'supplier'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tpsetsCustomer = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'customer'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tif spaceUser && spaceUser.profile\n\t\t\tpsetsCurrent = Creator.getCollection(\"permission_set\").find({space: spaceId, $or: [{users: userId}, {name: spaceUser.profile}]}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\telse\n\t\t\tpsetsCurrent = Creator.getCollection(\"permission_set\").find({users: userId, space: spaceId}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\n\t\tpsetsAdmin_pos = null\n\t\tpsetsUser_pos = null\n\t\tpsetsMember_pos = null\n\t\tpsetsGuest_pos = null\n\t\tpsetsCurrent_pos = null\n\t\tpsetsSupplier_pos = null\n\t\tpsetsCustomer_pos = null\n\n\t\tif psetsAdmin?._id\n\t\t\tpsetsAdmin_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsAdmin._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsUser?._id\n\t\t\tpsetsUser_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsUser._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsMember?._id\n\t\t\tpsetsMember_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsMember._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsGuest?._id\n\t\t\tpsetsGuest_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsGuest._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsSupplier?._id\n\t\t\tpsetsSupplier_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsSupplier._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsCustomer?._id\n\t\t\tpsetsCustomer_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsCustomer._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\n\t\tif psetsCurrent.length > 0\n\t\t\tset_ids = _.pluck psetsCurrent, \"_id\"\n\t\t\tpsetsCurrent_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: {$in: set_ids}}).fetch()\n\t\t\tpsetsCurrentNames = _.pluck psetsCurrent, \"name\"\n\t\tpsets = {\n\t\t\tpsetsAdmin, \n\t\t\tpsetsUser, \n\t\t\tpsetsCurrent, \n\t\t\tpsetsMember, \n\t\t\tpsetsGuest,\n\t\t\tpsetsSupplier,\n\t\t\tpsetsCustomer,\n\t\t\tisSpaceAdmin,\n\t\t\tspaceUser, \n\t\t\tpsetsAdmin_pos, \n\t\t\tpsetsUser_pos, \n\t\t\tpsetsMember_pos, \n\t\t\tpsetsGuest_pos,\n\t\t\tpsetsSupplier_pos,\n\t\t\tpsetsCustomer_pos,\n\t\t\tpsetsCurrent_pos\n\t\t}\n\t\tpermissions.assigned_apps = Creator.getAssignedApps.bind(psets)(spaceId, userId)\n\t\tpermissions.assigned_menus = Creator.getAssignedMenus.bind(psets)(spaceId, userId)\n\t\tpermissions.user_permission_sets = psetsCurrentNames\n\t\t_i = 0\n\t\t_.each Creator.objectsByName, (object, object_name)->\n\t\t\t_i++\n\t\t\tif !_.has(object, 'space') || !object.space || object.space == spaceId\n\t\t\t\tif !_.has(object, 'in_development') || object.in_development == '0' || (object.in_development != '0' && isSpaceAdmin)\n\t\t\t\t\tpermissions.objects[object_name] = Creator.convertObject(clone(Creator.Objects[object_name]), spaceId)\n\t\t\t\t\tpermissions.objects[object_name][\"permissions\"] = Creator.getObjectPermissions.bind(psets)(spaceId, userId, object_name)\n\t\treturn permissions\n\n\tunionPlus = (array, other) ->\n\t\tif !array and !other\n\t\t\treturn undefined\n\t\tif !array\n\t\t\tarray = []\n\t\tif !other\n\t\t\tother = []\n\t\treturn _.union(array, other)\n\n\tintersectionPlus = (array, other) ->\n\t\tif !array and !other\n\t\t\treturn undefined\n\t\tif !array\n\t\t\tarray = []\n\t\tif !other\n\t\t\tother = []\n\t\treturn _.intersection(array, other)\n\n\textendPermissionProps = (target, props) ->\n\t\tpropNames = permissionPropNames\n\t\tfilesProNames = \n\t\tif props\n\t\t\t_.each propNames, (propName) ->\n\t\t\t\ttarget[propName] = props[propName]\n\n\t\t\t# target.allowCreate = props.allowCreate\n\t\t\t# target.allowDelete = props.allowDelete\n\t\t\t# target.allowEdit = props.allowEdit\n\t\t\t# target.allowRead = props.allowRead\n\t\t\t# target.modifyAllRecords = props.modifyAllRecords\n\t\t\t# target.viewAllRecords = props.viewAllRecords\n\t\t\t# target.modifyCompanyRecords = props.modifyCompanyRecords\n\t\t\t# target.viewCompanyRecords = props.viewCompanyRecords\n\t\t\t# target.disabled_list_views = props.disabled_list_views\n\t\t\t# target.disabled_actions = props.disabled_actions\n\t\t\t# target.unreadable_fields = props.unreadable_fields\n\t\t\t# target.uneditable_fields = props.uneditable_fields\n\t\t\t# target.unrelated_objects = props.unrelated_objects\n\t\t\t# target.uneditable_related_list = props.uneditable_related_list\n\n\toverlayBaseBooleanPermissionProps = (target, props) ->\n\t\tpropNames = baseBooleanPermissionPropNames\n\t\t_.each propNames, (propName) ->\n\t\t\tif props[propName]\n\t\t\t\ttarget[propName] = true\n\t\t\n\t\t# if po.allowRead\n\t\t# \tpermissions.allowRead = true\n\t\t# if po.allowCreate\n\t\t# \tpermissions.allowCreate = true\n\t\t# if po.allowEdit\n\t\t# \tpermissions.allowEdit = true\n\t\t# if po.allowDelete\n\t\t# \tpermissions.allowDelete = true\n\t\t# if po.modifyAllRecords\n\t\t# \tpermissions.modifyAllRecords = true\n\t\t# if po.viewAllRecords\n\t\t# \tpermissions.viewAllRecords = true\n\t\t# if po.modifyCompanyRecords\n\t\t# \tpermissions.modifyCompanyRecords = true\n\t\t# if po.viewCompanyRecords\n\t\t# \tpermissions.viewCompanyRecords = true\n\n\n\tCreator.getAssignedApps = (spaceId, userId)->\n\t\tpsetsAdmin = this.psetsAdmin || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'admin'}, {fields:{_id:1, assigned_apps:1}})\n\t\tpsetsUser = this.psetsUser || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'user'}, {fields:{_id:1, assigned_apps:1}})\n\t\tpsetsSupplier = this.psetsMember || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'supplier'}, {fields:{_id:1, assigned_apps:1}})\n\t\tpsetsCustomer = this.psetsGuest || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'customer'}, {fields:{_id:1, assigned_apps:1}})\n\t\t# psetsMember = this.psetsMember || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'member'}, {fields:{_id:1, assigned_apps:1}})\n\t\t# psetsGuest = this.psetsGuest || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'guest'}, {fields:{_id:1, assigned_apps:1}})\n\t\tspaceUser = null;\n\t\tif userId\n\t\t\tspaceUser = Creator.getCollection(\"space_users\").findOne({ space: spaceId, user: userId }, { fields: { profile: 1 } })\n\t\tif spaceUser && spaceUser.profile\n\t\t\tpsets = Creator.getCollection(\"permission_set\").find({space: spaceId, $or: [{users: userId}, {name: spaceUser.profile}]}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\telse\n\t\t\tpsets = Creator.getCollection(\"permission_set\").find({users: userId, space: spaceId}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\tisSpaceAdmin = if _.isBoolean(this.isSpaceAdmin) then this.isSpaceAdmin else Creator.isSpaceAdmin(spaceId, userId)\n\t\tapps = []\n\t\tif isSpaceAdmin\n\t\t\treturn []\n\t\telse\n\t\t\tuserProfile = Creator.getCollection(\"space_users\").findOne({space: spaceId, user: userId}, {fields: {profile: 1}})?.profile\n\t\t\tpsetBase = psetsUser\n\t\t\tif userProfile\n\t\t\t\tif userProfile == 'supplier'\n\t\t\t\t\tpsetBase = psetsSupplier\n\t\t\t\telse if userProfile == 'customer'\n\t\t\t\t\tpsetBase = psetsCustomer\n\t\t\tif psetBase?.assigned_apps?.length\n\t\t\t\tapps = _.union apps, psetBase.assigned_apps\n\t\t\telse\n\t\t\t\t# user权限集中的assigned_apps表示所有用户具有的apps权限，为空则表示有所有apps权限，不需要作权限判断了\n\t\t\t\treturn []\n\t\t\t_.each psets, (pset)->\n\t\t\t\tif !pset.assigned_apps\n\t\t\t\t\treturn\n\t\t\t\tif pset.name == \"admin\" ||  pset.name == \"user\" || pset.name == 'supplier' || pset.name == 'customer'\n\t\t\t\t\t# 这里之所以要排除admin/user，是因为这两个权限集是所有权限集中users属性无效的权限集，特指工作区管理员和所有用户\n\t\t\t\t\treturn\n\t\t\t\tapps = _.union apps, pset.assigned_apps\n\t\t\treturn _.without(_.uniq(apps),undefined,null)\n\n\tCreator.getAssignedMenus = (spaceId, userId)->\n\t\tpsets =  this.psetsCurrent || Creator.getCollection(\"permission_set\").find({users: userId, space: spaceId}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\tisSpaceAdmin = if _.isBoolean(this.isSpaceAdmin) then this.isSpaceAdmin else Creator.isSpaceAdmin(spaceId, userId)\n\t\tadminMenus = Creator.Apps.admin?.admin_menus\n\t\t# 如果没有admin菜单说明不需要相关功能，直接返回空\n\t\tunless adminMenus\n\t\t\treturn []\n\t\taboutMenu = adminMenus.find (n) ->\n\t\t\tn._id == 'about'\n\t\tadminMenus = adminMenus.filter (n) ->\n\t\t\tn._id != 'about'\n\t\totherMenuApps = _.sortBy _.filter(_.values(Creator.Apps), (n) ->\n\t\t\treturn n.admin_menus and n._id != 'admin'\n\t\t), 'sort'\n\t\totherMenus = _.flatten(_.pluck(otherMenuApps, \"admin_menus\"))\n\t\t# 菜单有三部分组成，设置APP菜单、其他APP菜单以及about菜单\n\t\tallMenus = _.union(adminMenus, otherMenus, [aboutMenu])\n\t\tif isSpaceAdmin\n\t\t\t# 工作区管理员有全部菜单功能\n\t\t\tresult = allMenus\n\t\telse\n\t\t\tuserProfile = Creator.getCollection(\"space_users\").findOne({space: spaceId, user: userId}, {fields: {profile: 1}})?.profile || 'user'\n\t\t\tcurrentPsetNames = psets.map (n) ->\n\t\t\t\treturn n.name\n\t\t\tmenus = allMenus.filter (menu)->\n\t\t\t\tpsetsMenu = menu.permission_sets\n\t\t\t\t# 如果普通用户有权限，则直接返回true\n\t\t\t\tif psetsMenu && psetsMenu.indexOf(userProfile) > -1\n\t\t\t\t\treturn true\n\t\t\t\t# 否则取当前用户的权限集与menu菜单要求的权限集对比，如果交集大于1个则返回true\n\t\t\t\treturn _.intersection(currentPsetNames, psetsMenu).length\n\t\t\tresult = menus\n\t\t\n\t\treturn _.sortBy(result,\"sort\")\n\n\tfindOne_permission_object = (permission_objects, object_name, permission_set_id)->\n\n\t\tif _.isNull(permission_objects)\n\t\t\treturn null\n\t\tif _.isArray(permission_objects)\n\t\t\treturn _.find permission_objects, (po)->\n\t\t\t\t\treturn po.object_name == object_name\n\t\treturn Creator.getCollection(\"permission_objects\").findOne({object_name: object_name, permission_set_id: permission_set_id})\n\n\tfind_permission_object = (permission_objects, object_name, permission_set_ids)->\n\t\tif _.isNull(permission_objects)\n\t\t\treturn null\n\t\tif _.isArray(permission_objects)\n\t\t\treturn _.filter permission_objects, (po)->\n\t\t\t\treturn po.object_name == object_name\n\t\tCreator.getCollection(\"permission_objects\").find({object_name: object_name, permission_set_id: {$in: permission_set_ids}}).fetch()\n\n\tunionPermissionObjects = (pos, object, psets)->\n\t\t# 把db及yml中的permission_objects合并，优先取db中的\n\t\tresult = []\n\t\t_.each object.permission_set, (ops, ops_key)->\n\t\t\t# 把yml中除了特定用户集合权限集\"admin\", \"user\", \"member\", \"guest\"外的其他对象权限先存入result\n\t\t\t# if [\"admin\", \"user\", \"member\", \"guest\", \"workflow_admin\", \"organization_admin\"].indexOf(ops_key) < 0\n\t\t\tif [\"admin\", \"user\", \"member\", \"guest\"].indexOf(ops_key) < 0\n\t\t\t\tcurrentPset = psets.find (pset)-> return pset.name == ops_key\n\t\t\t\tif currentPset\n\t\t\t\t\ttempOps = _.clone(ops) || {}\n\t\t\t\t\ttempOps.permission_set_id = currentPset._id\n\t\t\t\t\ttempOps.object_name = object.object_name\n\t\t\t\t\tresult.push tempOps\n\t\tif result.length\n\t\t\tpos.forEach (po)->\n\t\t\t\trepeatIndex = 0\n\t\t\t\trepeatPo = result.find((item, index)-> repeatIndex = index;return item.permission_set_id == po.permission_set_id)\n\t\t\t\t# 如果yml中已经存在po，则替换为数据库中的po，反之则把数据库中的po直接累加进去\n\t\t\t\tif repeatPo\n\t\t\t\t\tresult[repeatIndex] = po\n\t\t\t\telse\n\t\t\t\t\tresult.push po\n\t\t\treturn result\n\t\telse\n\t\t\treturn pos\n\n\tCreator.getObjectPermissions = (spaceId, userId, object_name)->\n\t\tpermissions = {}\n\t\tobject = Creator.getObject(object_name, spaceId)\n\n\t\tif spaceId is 'guest' || object_name == \"users\"\n\t\t\tpermissions = _.clone(object.permission_set.guest) || {}\n\t\t\tCreator.processPermissions permissions\n\t\t\treturn permissions\n\t\tpsetsAdmin = if _.isNull(this.psetsAdmin) or this.psetsAdmin then this.psetsAdmin else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'admin'}, {fields:{_id:1}})\n\t\tpsetsUser = if _.isNull(this.psetsUser) or this.psetsUser then this.psetsUser else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'user'}, {fields:{_id:1}})\n\t\tpsetsMember = if _.isNull(this.psetsMember) or this.psetsMember then this.psetsMember else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'member'}, {fields:{_id:1}})\n\t\tpsetsGuest = if _.isNull(this.psetsGuest) or this.psetsGuest then this.psetsGuest else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'guest'}, {fields:{_id:1}})\n\n\t\tpsetsSupplier = if _.isNull(this.psetsSupplier) or this.psetsSupplier then this.psetsSupplier else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'supplier'}, {fields:{_id:1}})\n\t\tpsetsCustomer = if _.isNull(this.psetsCustomer) or this.psetsCustomer then this.psetsCustomer else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'customer'}, {fields:{_id:1}})\n\t\tpsets = this.psetsCurrent;\n\t\tif !psets\n\t\t\tspaceUser = null;\n\t\t\tif userId\n\t\t\t\tspaceUser = Creator.getCollection(\"space_users\").findOne({ space: spaceId, user: userId }, { fields: { profile: 1 } })\n\t\t\tif spaceUser && spaceUser.profile\n\t\t\t\tpsets = Creator.getCollection(\"permission_set\").find({space: spaceId, $or: [{users: userId}, {name: spaceUser.profile}]}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\t\telse\n\t\t\t\tpsets = Creator.getCollection(\"permission_set\").find({users: userId, space: spaceId}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\tisSpaceAdmin = if _.isBoolean(this.isSpaceAdmin) then this.isSpaceAdmin else Creator.isSpaceAdmin(spaceId, userId)\n\n\t\tpsetsAdmin_pos = this.psetsAdmin_pos\n\t\tpsetsUser_pos = this.psetsUser_pos\n\t\tpsetsMember_pos = this.psetsMember_pos\n\t\tpsetsGuest_pos = this.psetsGuest_pos\n\n\t\tpsetsSupplier_pos = this.psetsSupplier_pos\n\t\tpsetsCustomer_pos = this.psetsCustomer_pos\n\n\t\tpsetsCurrent_pos = this.psetsCurrent_pos\n\n\t\topsetAdmin = _.clone(object.permission_set.admin) || {}\n\t\topsetUser = _.clone(object.permission_set.user) || {}\n\t\topsetMember = _.clone(object.permission_set.member) || {}\n\t\topsetGuest = _.clone(object.permission_set.guest) || {}\n\n\t\topsetSupplier = _.clone(object.permission_set.supplier) || {}\n\t\topsetCustomer = _.clone(object.permission_set.customer) || {}\n\n\t\t# sharedListViews = Creator.getCollection('object_listviews').find({space: spaceId, object_name: object_name, shared: true}, {fields:{_id:1}}).fetch()\n\t\t# sharedListViews = _.pluck(sharedListViews,\"_id\")\n\t\t# if sharedListViews.length\n\t\t# \tunless opsetAdmin.list_views\n\t\t# \t\topsetAdmin.list_views = []\n\t\t# \topsetAdmin.list_views = _.union opsetAdmin.list_views, sharedListViews\n\t\t# \tunless opsetUser.list_views\n\t\t# \t\topsetUser.list_views = []\n\t\t# \topsetUser.list_views = _.union opsetUser.list_views, sharedListViews\n\t\t# 数据库中如果配置了默认的admin/user权限集设置，应该覆盖代码中admin/user的权限集设置\n\t\tif psetsAdmin\n\t\t\tposAdmin = findOne_permission_object(psetsAdmin_pos, object_name, psetsAdmin._id)\n\t\t\textendPermissionProps opsetAdmin, posAdmin\n\t\tif psetsUser\n\t\t\tposUser = findOne_permission_object(psetsUser_pos, object_name, psetsUser._id)\n\t\t\textendPermissionProps opsetUser, posUser\n\t\tif psetsMember\n\t\t\tposMember = findOne_permission_object(psetsMember_pos, object_name, psetsMember._id)\n\t\t\textendPermissionProps opsetMember, posMember\n\t\tif psetsGuest\n\t\t\tposGuest = findOne_permission_object(psetsGuest_pos, object_name, psetsGuest._id)\n\t\t\textendPermissionProps opsetGuest, posGuest\n\t\tif psetsSupplier\n\t\t\tposSupplier = findOne_permission_object(psetsSupplier_pos, object_name, psetsSupplier._id);\n\t\t\textendPermissionProps opsetSupplier, posSupplier\n\t\tif psetsCustomer\n\t\t\tposCustomer = findOne_permission_object(psetsCustomer_pos, object_name, psetsCustomer._id);\n\t\t\textendPermissionProps opsetCustomer, posCustomer\n\n\t\tif !userId\n\t\t\tpermissions = opsetAdmin\n\t\telse\n\t\t\tif isSpaceAdmin\n\t\t\t\tpermissions = opsetAdmin\n\t\t\telse\n\t\t\t\tif spaceId is 'common'\n\t\t\t\t\tpermissions = opsetUser\n\t\t\t\telse\n\t\t\t\t\tspaceUser = if _.isNull(this.spaceUser) or this.spaceUser then this.spaceUser else Creator.getCollection(\"space_users\").findOne({ space: spaceId, user: userId }, { fields: { profile: 1 } })\n\t\t\t\t\tif spaceUser\n\t\t\t\t\t\tprof = spaceUser.profile\n\t\t\t\t\t\tif prof\n\t\t\t\t\t\t\tif prof is 'user'\n\t\t\t\t\t\t\t\tpermissions = opsetUser\n\t\t\t\t\t\t\telse if prof is 'member'\n\t\t\t\t\t\t\t\tpermissions = opsetMember\n\t\t\t\t\t\t\telse if prof is 'guest'\n\t\t\t\t\t\t\t\tpermissions = opsetGuest\n\t\t\t\t\t\t\telse if prof is 'supplier'\n\t\t\t\t\t\t\t\tpermissions = opsetSupplier\n\t\t\t\t\t\t\telse if prof is 'customer'\n\t\t\t\t\t\t\t\tpermissions = opsetCustomer\n\t\t\t\t\t\telse # 没有profile则认为是user权限\n\t\t\t\t\t\t\tpermissions = opsetUser\n\t\t\t\t\telse\n\t\t\t\t\t\tpermissions = opsetGuest\n\t\tif psets.length > 0\n\t\t\tset_ids = _.pluck psets, \"_id\"\n\t\t\tpos = find_permission_object(psetsCurrent_pos, object_name, set_ids)\n\t\t\tpos = unionPermissionObjects(pos, object, psets)\n\t\t\t_.each pos, (po)->\n\t\t\t\tif po.permission_set_id == psetsAdmin?._id or \n\t\t\t\tpo.permission_set_id == psetsUser?._id or \n\t\t\t\tpo.permission_set_id == psetsMember?._id or \n\t\t\t\tpo.permission_set_id == psetsGuest?._id or\n\t\t\t\tpo.permission_set_id == psetsSupplier?._id or\n\t\t\t\tpo.permission_set_id == psetsCustomer?._id\n\t\t\t\t\t# 默认的admin/user权限值只实行上面的默认值覆盖，不做算法判断\n\t\t\t\t\treturn\n\t\t\t\tif _.isEmpty(permissions)\n\t\t\t\t\tpermissions = po\n\t\t\t\toverlayBaseBooleanPermissionProps permissions, po\n\n\t\t\t\tpermissions.disabled_list_views = intersectionPlus(permissions.disabled_list_views, po.disabled_list_views)\n\t\t\t\tpermissions.disabled_actions = intersectionPlus(permissions.disabled_actions, po.disabled_actions)\n\t\t\t\tpermissions.unreadable_fields = intersectionPlus(permissions.unreadable_fields, po.unreadable_fields)\n\t\t\t\tpermissions.uneditable_fields = intersectionPlus(permissions.uneditable_fields, po.uneditable_fields)\n\t\t\t\tpermissions.unrelated_objects = intersectionPlus(permissions.unrelated_objects, po.unrelated_objects)\n\t\t\t\tpermissions.uneditable_related_list = intersectionPlus(permissions.uneditable_related_list, po.uneditable_related_list)\n\t\t\n\t\tif object.is_view\n\t\t\tpermissions.allowCreate = false\n\t\t\tpermissions.allowEdit = false\n\t\t\tpermissions.allowDelete = false\n\t\t\tpermissions.modifyAllRecords = false\n\t\t\tpermissions.modifyCompanyRecords = false\n\t\t\tpermissions.disabled_actions = []\n\t\tCreator.processPermissions permissions\n\n\t\tif object.permission_set.owner\n\t\t\tpermissions.owner = object.permission_set.owner\n\t\treturn permissions\n\n\n\t# Creator.initPermissions = (object_name) ->\n\n\t\t# # 应该把计算出来的\n\t\t# Creator.Collections[object_name].allow\n\t\t# \tinsert: (userId, doc) ->\n\t\t# \t\tif !userId\n\t\t# \t\t\treturn false\n\t\t# \t\tif !doc.space\n\t\t# \t\t\treturn false\n\t    \t# \t\tpermissions = Creator.getObjectPermissions(doc.space, userId, object_name)\n\t\t# \t\tif !permissions.allowCreate\n\t\t# \t\t\treturn false\n\n\t\t# \t\treturn true\n\t\t# \tupdate: (userId, doc) ->\n\t\t# \t\tif !userId\n\t\t# \t\t\treturn false\n\t\t# \t\tif !doc.space\n\t\t# \t\t\treturn false\n\t\t# \t\tpermissions = Creator.getObjectPermissions(doc.space, userId, object_name)\n\t\t# \t\tif !permissions.allowEdit\n\t\t# \t\t\treturn false\n\t\t# \t\treturn true\n\t\t# \tremove: (userId, doc) ->\n\t\t# \t\tif !userId\n\t\t# \t\t\treturn false\n\t\t# \t\tif !doc.space\n\t\t# \t\t\treturn false\n\t\t# \t\tpermissions = Creator.getObjectPermissions(doc.space, userId, object_name)\n\t\t# \t\tif !permissions.allowDelete\n\t\t# \t\t\treturn false\n\t\t# \t\treturn true\n\n\tMeteor.methods\n\t\t# Calculate Permissions on Server\n\t\t\"creator.object_permissions\": (spaceId)->\n\t\t\treturn Creator.getAllPermissions(spaceId, this.userId)\n","var baseBooleanPermissionPropNames, clone, extendPermissionProps, findOne_permission_object, find_permission_object, intersectionPlus, otherPermissionPropNames, overlayBaseBooleanPermissionProps, permissionPropNames, unionPermissionObjects, unionPlus;\n\nclone = require('clone');\n\nbaseBooleanPermissionPropNames = [\"allowCreate\", \"allowDelete\", \"allowEdit\", \"allowRead\", \"modifyAllRecords\", \"viewAllRecords\", \"modifyCompanyRecords\", \"viewCompanyRecords\", \"allowReadFiles\", \"allowEditFiles\", \"allowCreateFiles\", \"allowDeleteFiles\", \"viewAllFiles\", \"modifyAllFiles\"];\n\notherPermissionPropNames = [\"disabled_list_views\", \"disabled_actions\", \"unreadable_fields\", \"uneditable_fields\", \"unrelated_objects\", \"uneditable_related_list\"];\n\npermissionPropNames = _.union(baseBooleanPermissionPropNames, otherPermissionPropNames);\n\nCreator.getPermissions = function(object_name, spaceId, userId) {\n  var obj;\n  if (Meteor.isClient) {\n    if (!object_name) {\n      object_name = Session.get(\"object_name\");\n    }\n    obj = Creator.getObject(object_name);\n    if (!obj) {\n      return;\n    }\n    return obj.permissions.get();\n  } else if (Meteor.isServer) {\n    return Creator.getObjectPermissions(spaceId, userId, object_name);\n  }\n};\n\nCreator.getRecordPermissions = function(object_name, record, userId, spaceId) {\n  var isOwner, masterObjectName, masterRecordPerm, permissions, record_company_id, record_company_ids, ref, user_company_ids;\n  if (!object_name && Meteor.isClient) {\n    object_name = Session.get(\"object_name\");\n  }\n  if (!spaceId && Meteor.isClient) {\n    spaceId = Session.get(\"spaceId\");\n  }\n  permissions = _.clone(Creator.getPermissions(object_name, spaceId, userId));\n  if (record) {\n    if (!_.isEmpty(record.record_permissions)) {\n      return record.record_permissions;\n    }\n    isOwner = record.owner === userId || ((ref = record.owner) != null ? ref._id : void 0) === userId;\n    if (object_name === \"cms_files\") {\n      masterObjectName = record.parent['reference_to._o'];\n      masterRecordPerm = Creator.getPermissions(masterObjectName, spaceId, userId);\n      permissions.allowCreate = permissions.allowCreate && masterRecordPerm.allowCreateFiles;\n      permissions.allowEdit = permissions.allowEdit && masterRecordPerm.allowEditFiles;\n      permissions.allowDelete = permissions.allowDelete && masterRecordPerm.allowDeleteFiles;\n      if (!masterRecordPerm.modifyAllFiles && !isOwner) {\n        permissions.allowEdit = false;\n        permissions.allowDelete = false;\n      }\n      permissions.allowRead = permissions.allowRead && masterRecordPerm.allowReadFiles;\n      if (!masterRecordPerm.viewAllFiles && !isOwner) {\n        permissions.allowRead = false;\n      }\n    } else {\n      if (Meteor.isClient) {\n        user_company_ids = Steedos.getUserCompanyIds();\n      } else {\n        user_company_ids = Creator.getUserCompanyIds(userId, spaceId);\n      }\n      record_company_id = record != null ? record.company_id : void 0;\n      if (record_company_id && _.isObject(record_company_id) && record_company_id._id) {\n        record_company_id = record_company_id._id;\n      }\n      record_company_ids = record != null ? record.company_ids : void 0;\n      if (record_company_ids && record_company_ids.length && _.isObject(record_company_ids[0])) {\n        record_company_ids = record_company_ids.map(function(n) {\n          return n._id;\n        });\n      }\n      record_company_ids = _.union(record_company_ids, [record_company_id]);\n      if (!permissions.modifyAllRecords && !isOwner && !permissions.modifyCompanyRecords) {\n        permissions.allowEdit = false;\n        permissions.allowDelete = false;\n      } else if (!permissions.modifyAllRecords && permissions.modifyCompanyRecords) {\n        if (record_company_ids && record_company_ids.length) {\n          if (user_company_ids && user_company_ids.length) {\n            if (!_.intersection(user_company_ids, record_company_ids).length) {\n              permissions.allowEdit = false;\n              permissions.allowDelete = false;\n            }\n          } else {\n            permissions.allowEdit = false;\n            permissions.allowDelete = false;\n          }\n        }\n      }\n      if (record.locked && !permissions.modifyAllRecords) {\n        permissions.allowEdit = false;\n        permissions.allowDelete = false;\n      }\n      if (!permissions.viewAllRecords && !isOwner && !permissions.viewCompanyRecords) {\n        permissions.allowRead = false;\n      } else if (!permissions.viewAllRecords && permissions.viewCompanyRecords) {\n        if (record_company_ids && record_company_ids.length) {\n          if (user_company_ids && user_company_ids.length) {\n            if (!_.intersection(user_company_ids, record_company_ids).length) {\n              permissions.allowRead = false;\n            }\n          } else {\n            permissions.allowRead = false;\n          }\n        }\n      }\n    }\n  }\n  return permissions;\n};\n\nif (Meteor.isClient) {\n  Creator.getRecordRelatedListPermissions = function(currentObjectName, relatedListItem, currentRecord, userId, spaceId) {\n    var isRelateObjectUneditable, masterAllow, masterRecordPerm, relatedObjectPermissions, result, uneditable_related_list, write_requires_master_read;\n    if (!currentObjectName && Meteor.isClient) {\n      currentObjectName = Session.get(\"object_name\");\n    }\n    if (!relatedListItem) {\n      console.error(\"relatedListItem must not be empty for the function Creator.getRecordRelatedListPermissions\");\n      return {};\n    }\n    if (!currentRecord && Meteor.isClient) {\n      currentRecord = Creator.getObjectRecord();\n    }\n    if (!userId && Meteor.isClient) {\n      userId = Meteor.userId();\n    }\n    if (!spaceId && Meteor.isClient) {\n      spaceId = Session.get(\"spaceId\");\n    }\n    masterRecordPerm = Creator.getRecordPermissions(currentObjectName, currentRecord, userId, spaceId);\n    relatedObjectPermissions = Creator.getPermissions(relatedListItem.object_name);\n    result = _.clone(relatedObjectPermissions);\n    if (relatedListItem.is_file) {\n      result.allowCreate = relatedObjectPermissions.allowCreate && masterRecordPerm.allowCreateFiles;\n      result.allowEdit = relatedObjectPermissions.allowEdit && masterRecordPerm.allowEditFiles;\n    } else {\n      write_requires_master_read = relatedListItem.write_requires_master_read || false;\n      masterAllow = false;\n      if (write_requires_master_read === true) {\n        masterAllow = masterRecordPerm.allowRead;\n      } else if (write_requires_master_read === false) {\n        masterAllow = masterRecordPerm.allowEdit;\n      }\n      uneditable_related_list = Creator.getRecordSafeRelatedList(currentRecord, currentObjectName);\n      isRelateObjectUneditable = uneditable_related_list.indexOf(relatedListItem.object_name) > -1;\n      result.allowCreate = masterAllow && relatedObjectPermissions.allowCreate && !isRelateObjectUneditable;\n      result.allowEdit = masterAllow && relatedObjectPermissions.allowEdit && !isRelateObjectUneditable;\n    }\n    return result;\n  };\n}\n\nif (Meteor.isServer) {\n  Creator.getAllPermissions = function(spaceId, userId) {\n    var _i, isSpaceAdmin, permissions, psets, psetsAdmin, psetsAdmin_pos, psetsCurrent, psetsCurrentNames, psetsCurrent_pos, psetsCustomer, psetsCustomer_pos, psetsGuest, psetsGuest_pos, psetsMember, psetsMember_pos, psetsSupplier, psetsSupplier_pos, psetsUser, psetsUser_pos, set_ids, spaceUser;\n    permissions = {\n      objects: {},\n      assigned_apps: []\n    };\n\n    /*\n    \t\t权限集说明:\n    \t\t内置权限集-admin,user,member,guest,workflow_admin,organization_admin\n    \t\t自定义权限集-数据库中新建的除内置权限集以外的其他权限集\n    \t\t特定用户集合权限集（即users属性不可配置）-admin,user,member,guest\n    \t\t可配置用户集合权限集（即users属性可配置）-workflow_admin,organization_admin以及自定义权限集\n     */\n    isSpaceAdmin = false;\n    spaceUser = null;\n    if (userId) {\n      isSpaceAdmin = Creator.isSpaceAdmin(spaceId, userId);\n      spaceUser = Creator.getCollection(\"space_users\").findOne({\n        space: spaceId,\n        user: userId\n      }, {\n        fields: {\n          profile: 1\n        }\n      });\n    }\n    psetsAdmin = Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'admin'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    }) || null;\n    psetsUser = Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'user'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    }) || null;\n    psetsMember = Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'member'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    }) || null;\n    psetsGuest = Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'guest'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    }) || null;\n    psetsSupplier = Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'supplier'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    }) || null;\n    psetsCustomer = Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'customer'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    }) || null;\n    if (spaceUser && spaceUser.profile) {\n      psetsCurrent = Creator.getCollection(\"permission_set\").find({\n        space: spaceId,\n        $or: [\n          {\n            users: userId\n          }, {\n            name: spaceUser.profile\n          }\n        ]\n      }, {\n        fields: {\n          _id: 1,\n          assigned_apps: 1,\n          name: 1\n        }\n      }).fetch();\n    } else {\n      psetsCurrent = Creator.getCollection(\"permission_set\").find({\n        users: userId,\n        space: spaceId\n      }, {\n        fields: {\n          _id: 1,\n          assigned_apps: 1,\n          name: 1\n        }\n      }).fetch();\n    }\n    psetsAdmin_pos = null;\n    psetsUser_pos = null;\n    psetsMember_pos = null;\n    psetsGuest_pos = null;\n    psetsCurrent_pos = null;\n    psetsSupplier_pos = null;\n    psetsCustomer_pos = null;\n    if (psetsAdmin != null ? psetsAdmin._id : void 0) {\n      psetsAdmin_pos = Creator.getCollection(\"permission_objects\").find({\n        permission_set_id: psetsAdmin._id\n      }, {\n        fields: {\n          created: 0,\n          modified: 0,\n          created_by: 0,\n          modified_by: 0\n        }\n      }).fetch();\n    }\n    if (psetsUser != null ? psetsUser._id : void 0) {\n      psetsUser_pos = Creator.getCollection(\"permission_objects\").find({\n        permission_set_id: psetsUser._id\n      }, {\n        fields: {\n          created: 0,\n          modified: 0,\n          created_by: 0,\n          modified_by: 0\n        }\n      }).fetch();\n    }\n    if (psetsMember != null ? psetsMember._id : void 0) {\n      psetsMember_pos = Creator.getCollection(\"permission_objects\").find({\n        permission_set_id: psetsMember._id\n      }, {\n        fields: {\n          created: 0,\n          modified: 0,\n          created_by: 0,\n          modified_by: 0\n        }\n      }).fetch();\n    }\n    if (psetsGuest != null ? psetsGuest._id : void 0) {\n      psetsGuest_pos = Creator.getCollection(\"permission_objects\").find({\n        permission_set_id: psetsGuest._id\n      }, {\n        fields: {\n          created: 0,\n          modified: 0,\n          created_by: 0,\n          modified_by: 0\n        }\n      }).fetch();\n    }\n    if (psetsSupplier != null ? psetsSupplier._id : void 0) {\n      psetsSupplier_pos = Creator.getCollection(\"permission_objects\").find({\n        permission_set_id: psetsSupplier._id\n      }, {\n        fields: {\n          created: 0,\n          modified: 0,\n          created_by: 0,\n          modified_by: 0\n        }\n      }).fetch();\n    }\n    if (psetsCustomer != null ? psetsCustomer._id : void 0) {\n      psetsCustomer_pos = Creator.getCollection(\"permission_objects\").find({\n        permission_set_id: psetsCustomer._id\n      }, {\n        fields: {\n          created: 0,\n          modified: 0,\n          created_by: 0,\n          modified_by: 0\n        }\n      }).fetch();\n    }\n    if (psetsCurrent.length > 0) {\n      set_ids = _.pluck(psetsCurrent, \"_id\");\n      psetsCurrent_pos = Creator.getCollection(\"permission_objects\").find({\n        permission_set_id: {\n          $in: set_ids\n        }\n      }).fetch();\n      psetsCurrentNames = _.pluck(psetsCurrent, \"name\");\n    }\n    psets = {\n      psetsAdmin: psetsAdmin,\n      psetsUser: psetsUser,\n      psetsCurrent: psetsCurrent,\n      psetsMember: psetsMember,\n      psetsGuest: psetsGuest,\n      psetsSupplier: psetsSupplier,\n      psetsCustomer: psetsCustomer,\n      isSpaceAdmin: isSpaceAdmin,\n      spaceUser: spaceUser,\n      psetsAdmin_pos: psetsAdmin_pos,\n      psetsUser_pos: psetsUser_pos,\n      psetsMember_pos: psetsMember_pos,\n      psetsGuest_pos: psetsGuest_pos,\n      psetsSupplier_pos: psetsSupplier_pos,\n      psetsCustomer_pos: psetsCustomer_pos,\n      psetsCurrent_pos: psetsCurrent_pos\n    };\n    permissions.assigned_apps = Creator.getAssignedApps.bind(psets)(spaceId, userId);\n    permissions.assigned_menus = Creator.getAssignedMenus.bind(psets)(spaceId, userId);\n    permissions.user_permission_sets = psetsCurrentNames;\n    _i = 0;\n    _.each(Creator.objectsByName, function(object, object_name) {\n      _i++;\n      if (!_.has(object, 'space') || !object.space || object.space === spaceId) {\n        if (!_.has(object, 'in_development') || object.in_development === '0' || (object.in_development !== '0' && isSpaceAdmin)) {\n          permissions.objects[object_name] = Creator.convertObject(clone(Creator.Objects[object_name]), spaceId);\n          return permissions.objects[object_name][\"permissions\"] = Creator.getObjectPermissions.bind(psets)(spaceId, userId, object_name);\n        }\n      }\n    });\n    return permissions;\n  };\n  unionPlus = function(array, other) {\n    if (!array && !other) {\n      return void 0;\n    }\n    if (!array) {\n      array = [];\n    }\n    if (!other) {\n      other = [];\n    }\n    return _.union(array, other);\n  };\n  intersectionPlus = function(array, other) {\n    if (!array && !other) {\n      return void 0;\n    }\n    if (!array) {\n      array = [];\n    }\n    if (!other) {\n      other = [];\n    }\n    return _.intersection(array, other);\n  };\n  extendPermissionProps = function(target, props) {\n    var filesProNames, propNames;\n    propNames = permissionPropNames;\n    return filesProNames = props ? _.each(propNames, function(propName) {\n      return target[propName] = props[propName];\n    }) : void 0;\n  };\n  overlayBaseBooleanPermissionProps = function(target, props) {\n    var propNames;\n    propNames = baseBooleanPermissionPropNames;\n    return _.each(propNames, function(propName) {\n      if (props[propName]) {\n        return target[propName] = true;\n      }\n    });\n  };\n  Creator.getAssignedApps = function(spaceId, userId) {\n    var apps, isSpaceAdmin, psetBase, psets, psetsAdmin, psetsCustomer, psetsSupplier, psetsUser, ref, ref1, spaceUser, userProfile;\n    psetsAdmin = this.psetsAdmin || Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'admin'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    });\n    psetsUser = this.psetsUser || Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'user'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    });\n    psetsSupplier = this.psetsMember || Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'supplier'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    });\n    psetsCustomer = this.psetsGuest || Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'customer'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    });\n    spaceUser = null;\n    if (userId) {\n      spaceUser = Creator.getCollection(\"space_users\").findOne({\n        space: spaceId,\n        user: userId\n      }, {\n        fields: {\n          profile: 1\n        }\n      });\n    }\n    if (spaceUser && spaceUser.profile) {\n      psets = Creator.getCollection(\"permission_set\").find({\n        space: spaceId,\n        $or: [\n          {\n            users: userId\n          }, {\n            name: spaceUser.profile\n          }\n        ]\n      }, {\n        fields: {\n          _id: 1,\n          assigned_apps: 1,\n          name: 1\n        }\n      }).fetch();\n    } else {\n      psets = Creator.getCollection(\"permission_set\").find({\n        users: userId,\n        space: spaceId\n      }, {\n        fields: {\n          _id: 1,\n          assigned_apps: 1,\n          name: 1\n        }\n      }).fetch();\n    }\n    isSpaceAdmin = _.isBoolean(this.isSpaceAdmin) ? this.isSpaceAdmin : Creator.isSpaceAdmin(spaceId, userId);\n    apps = [];\n    if (isSpaceAdmin) {\n      return [];\n    } else {\n      userProfile = (ref = Creator.getCollection(\"space_users\").findOne({\n        space: spaceId,\n        user: userId\n      }, {\n        fields: {\n          profile: 1\n        }\n      })) != null ? ref.profile : void 0;\n      psetBase = psetsUser;\n      if (userProfile) {\n        if (userProfile === 'supplier') {\n          psetBase = psetsSupplier;\n        } else if (userProfile === 'customer') {\n          psetBase = psetsCustomer;\n        }\n      }\n      if (psetBase != null ? (ref1 = psetBase.assigned_apps) != null ? ref1.length : void 0 : void 0) {\n        apps = _.union(apps, psetBase.assigned_apps);\n      } else {\n        return [];\n      }\n      _.each(psets, function(pset) {\n        if (!pset.assigned_apps) {\n          return;\n        }\n        if (pset.name === \"admin\" || pset.name === \"user\" || pset.name === 'supplier' || pset.name === 'customer') {\n          return;\n        }\n        return apps = _.union(apps, pset.assigned_apps);\n      });\n      return _.without(_.uniq(apps), void 0, null);\n    }\n  };\n  Creator.getAssignedMenus = function(spaceId, userId) {\n    var aboutMenu, adminMenus, allMenus, currentPsetNames, isSpaceAdmin, menus, otherMenuApps, otherMenus, psets, ref, ref1, result, userProfile;\n    psets = this.psetsCurrent || Creator.getCollection(\"permission_set\").find({\n      users: userId,\n      space: spaceId\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1,\n        name: 1\n      }\n    }).fetch();\n    isSpaceAdmin = _.isBoolean(this.isSpaceAdmin) ? this.isSpaceAdmin : Creator.isSpaceAdmin(spaceId, userId);\n    adminMenus = (ref = Creator.Apps.admin) != null ? ref.admin_menus : void 0;\n    if (!adminMenus) {\n      return [];\n    }\n    aboutMenu = adminMenus.find(function(n) {\n      return n._id === 'about';\n    });\n    adminMenus = adminMenus.filter(function(n) {\n      return n._id !== 'about';\n    });\n    otherMenuApps = _.sortBy(_.filter(_.values(Creator.Apps), function(n) {\n      return n.admin_menus && n._id !== 'admin';\n    }), 'sort');\n    otherMenus = _.flatten(_.pluck(otherMenuApps, \"admin_menus\"));\n    allMenus = _.union(adminMenus, otherMenus, [aboutMenu]);\n    if (isSpaceAdmin) {\n      result = allMenus;\n    } else {\n      userProfile = ((ref1 = Creator.getCollection(\"space_users\").findOne({\n        space: spaceId,\n        user: userId\n      }, {\n        fields: {\n          profile: 1\n        }\n      })) != null ? ref1.profile : void 0) || 'user';\n      currentPsetNames = psets.map(function(n) {\n        return n.name;\n      });\n      menus = allMenus.filter(function(menu) {\n        var psetsMenu;\n        psetsMenu = menu.permission_sets;\n        if (psetsMenu && psetsMenu.indexOf(userProfile) > -1) {\n          return true;\n        }\n        return _.intersection(currentPsetNames, psetsMenu).length;\n      });\n      result = menus;\n    }\n    return _.sortBy(result, \"sort\");\n  };\n  findOne_permission_object = function(permission_objects, object_name, permission_set_id) {\n    if (_.isNull(permission_objects)) {\n      return null;\n    }\n    if (_.isArray(permission_objects)) {\n      return _.find(permission_objects, function(po) {\n        return po.object_name === object_name;\n      });\n    }\n    return Creator.getCollection(\"permission_objects\").findOne({\n      object_name: object_name,\n      permission_set_id: permission_set_id\n    });\n  };\n  find_permission_object = function(permission_objects, object_name, permission_set_ids) {\n    if (_.isNull(permission_objects)) {\n      return null;\n    }\n    if (_.isArray(permission_objects)) {\n      return _.filter(permission_objects, function(po) {\n        return po.object_name === object_name;\n      });\n    }\n    return Creator.getCollection(\"permission_objects\").find({\n      object_name: object_name,\n      permission_set_id: {\n        $in: permission_set_ids\n      }\n    }).fetch();\n  };\n  unionPermissionObjects = function(pos, object, psets) {\n    var result;\n    result = [];\n    _.each(object.permission_set, function(ops, ops_key) {\n      var currentPset, tempOps;\n      if ([\"admin\", \"user\", \"member\", \"guest\"].indexOf(ops_key) < 0) {\n        currentPset = psets.find(function(pset) {\n          return pset.name === ops_key;\n        });\n        if (currentPset) {\n          tempOps = _.clone(ops) || {};\n          tempOps.permission_set_id = currentPset._id;\n          tempOps.object_name = object.object_name;\n          return result.push(tempOps);\n        }\n      }\n    });\n    if (result.length) {\n      pos.forEach(function(po) {\n        var repeatIndex, repeatPo;\n        repeatIndex = 0;\n        repeatPo = result.find(function(item, index) {\n          repeatIndex = index;\n          return item.permission_set_id === po.permission_set_id;\n        });\n        if (repeatPo) {\n          return result[repeatIndex] = po;\n        } else {\n          return result.push(po);\n        }\n      });\n      return result;\n    } else {\n      return pos;\n    }\n  };\n  Creator.getObjectPermissions = function(spaceId, userId, object_name) {\n    var isSpaceAdmin, object, opsetAdmin, opsetCustomer, opsetGuest, opsetMember, opsetSupplier, opsetUser, permissions, pos, posAdmin, posCustomer, posGuest, posMember, posSupplier, posUser, prof, psets, psetsAdmin, psetsAdmin_pos, psetsCurrent_pos, psetsCustomer, psetsCustomer_pos, psetsGuest, psetsGuest_pos, psetsMember, psetsMember_pos, psetsSupplier, psetsSupplier_pos, psetsUser, psetsUser_pos, set_ids, spaceUser;\n    permissions = {};\n    object = Creator.getObject(object_name, spaceId);\n    if (spaceId === 'guest' || object_name === \"users\") {\n      permissions = _.clone(object.permission_set.guest) || {};\n      Creator.processPermissions(permissions);\n      return permissions;\n    }\n    psetsAdmin = _.isNull(this.psetsAdmin) || this.psetsAdmin ? this.psetsAdmin : Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'admin'\n    }, {\n      fields: {\n        _id: 1\n      }\n    });\n    psetsUser = _.isNull(this.psetsUser) || this.psetsUser ? this.psetsUser : Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'user'\n    }, {\n      fields: {\n        _id: 1\n      }\n    });\n    psetsMember = _.isNull(this.psetsMember) || this.psetsMember ? this.psetsMember : Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'member'\n    }, {\n      fields: {\n        _id: 1\n      }\n    });\n    psetsGuest = _.isNull(this.psetsGuest) || this.psetsGuest ? this.psetsGuest : Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'guest'\n    }, {\n      fields: {\n        _id: 1\n      }\n    });\n    psetsSupplier = _.isNull(this.psetsSupplier) || this.psetsSupplier ? this.psetsSupplier : Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'supplier'\n    }, {\n      fields: {\n        _id: 1\n      }\n    });\n    psetsCustomer = _.isNull(this.psetsCustomer) || this.psetsCustomer ? this.psetsCustomer : Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'customer'\n    }, {\n      fields: {\n        _id: 1\n      }\n    });\n    psets = this.psetsCurrent;\n    if (!psets) {\n      spaceUser = null;\n      if (userId) {\n        spaceUser = Creator.getCollection(\"space_users\").findOne({\n          space: spaceId,\n          user: userId\n        }, {\n          fields: {\n            profile: 1\n          }\n        });\n      }\n      if (spaceUser && spaceUser.profile) {\n        psets = Creator.getCollection(\"permission_set\").find({\n          space: spaceId,\n          $or: [\n            {\n              users: userId\n            }, {\n              name: spaceUser.profile\n            }\n          ]\n        }, {\n          fields: {\n            _id: 1,\n            assigned_apps: 1,\n            name: 1\n          }\n        }).fetch();\n      } else {\n        psets = Creator.getCollection(\"permission_set\").find({\n          users: userId,\n          space: spaceId\n        }, {\n          fields: {\n            _id: 1,\n            assigned_apps: 1,\n            name: 1\n          }\n        }).fetch();\n      }\n    }\n    isSpaceAdmin = _.isBoolean(this.isSpaceAdmin) ? this.isSpaceAdmin : Creator.isSpaceAdmin(spaceId, userId);\n    psetsAdmin_pos = this.psetsAdmin_pos;\n    psetsUser_pos = this.psetsUser_pos;\n    psetsMember_pos = this.psetsMember_pos;\n    psetsGuest_pos = this.psetsGuest_pos;\n    psetsSupplier_pos = this.psetsSupplier_pos;\n    psetsCustomer_pos = this.psetsCustomer_pos;\n    psetsCurrent_pos = this.psetsCurrent_pos;\n    opsetAdmin = _.clone(object.permission_set.admin) || {};\n    opsetUser = _.clone(object.permission_set.user) || {};\n    opsetMember = _.clone(object.permission_set.member) || {};\n    opsetGuest = _.clone(object.permission_set.guest) || {};\n    opsetSupplier = _.clone(object.permission_set.supplier) || {};\n    opsetCustomer = _.clone(object.permission_set.customer) || {};\n    if (psetsAdmin) {\n      posAdmin = findOne_permission_object(psetsAdmin_pos, object_name, psetsAdmin._id);\n      extendPermissionProps(opsetAdmin, posAdmin);\n    }\n    if (psetsUser) {\n      posUser = findOne_permission_object(psetsUser_pos, object_name, psetsUser._id);\n      extendPermissionProps(opsetUser, posUser);\n    }\n    if (psetsMember) {\n      posMember = findOne_permission_object(psetsMember_pos, object_name, psetsMember._id);\n      extendPermissionProps(opsetMember, posMember);\n    }\n    if (psetsGuest) {\n      posGuest = findOne_permission_object(psetsGuest_pos, object_name, psetsGuest._id);\n      extendPermissionProps(opsetGuest, posGuest);\n    }\n    if (psetsSupplier) {\n      posSupplier = findOne_permission_object(psetsSupplier_pos, object_name, psetsSupplier._id);\n      extendPermissionProps(opsetSupplier, posSupplier);\n    }\n    if (psetsCustomer) {\n      posCustomer = findOne_permission_object(psetsCustomer_pos, object_name, psetsCustomer._id);\n      extendPermissionProps(opsetCustomer, posCustomer);\n    }\n    if (!userId) {\n      permissions = opsetAdmin;\n    } else {\n      if (isSpaceAdmin) {\n        permissions = opsetAdmin;\n      } else {\n        if (spaceId === 'common') {\n          permissions = opsetUser;\n        } else {\n          spaceUser = _.isNull(this.spaceUser) || this.spaceUser ? this.spaceUser : Creator.getCollection(\"space_users\").findOne({\n            space: spaceId,\n            user: userId\n          }, {\n            fields: {\n              profile: 1\n            }\n          });\n          if (spaceUser) {\n            prof = spaceUser.profile;\n            if (prof) {\n              if (prof === 'user') {\n                permissions = opsetUser;\n              } else if (prof === 'member') {\n                permissions = opsetMember;\n              } else if (prof === 'guest') {\n                permissions = opsetGuest;\n              } else if (prof === 'supplier') {\n                permissions = opsetSupplier;\n              } else if (prof === 'customer') {\n                permissions = opsetCustomer;\n              }\n            } else {\n              permissions = opsetUser;\n            }\n          } else {\n            permissions = opsetGuest;\n          }\n        }\n      }\n    }\n    if (psets.length > 0) {\n      set_ids = _.pluck(psets, \"_id\");\n      pos = find_permission_object(psetsCurrent_pos, object_name, set_ids);\n      pos = unionPermissionObjects(pos, object, psets);\n      _.each(pos, function(po) {\n        if (po.permission_set_id === (psetsAdmin != null ? psetsAdmin._id : void 0) || po.permission_set_id === (psetsUser != null ? psetsUser._id : void 0) || po.permission_set_id === (psetsMember != null ? psetsMember._id : void 0) || po.permission_set_id === (psetsGuest != null ? psetsGuest._id : void 0) || po.permission_set_id === (psetsSupplier != null ? psetsSupplier._id : void 0) || po.permission_set_id === (psetsCustomer != null ? psetsCustomer._id : void 0)) {\n          return;\n        }\n        if (_.isEmpty(permissions)) {\n          permissions = po;\n        }\n        overlayBaseBooleanPermissionProps(permissions, po);\n        permissions.disabled_list_views = intersectionPlus(permissions.disabled_list_views, po.disabled_list_views);\n        permissions.disabled_actions = intersectionPlus(permissions.disabled_actions, po.disabled_actions);\n        permissions.unreadable_fields = intersectionPlus(permissions.unreadable_fields, po.unreadable_fields);\n        permissions.uneditable_fields = intersectionPlus(permissions.uneditable_fields, po.uneditable_fields);\n        permissions.unrelated_objects = intersectionPlus(permissions.unrelated_objects, po.unrelated_objects);\n        return permissions.uneditable_related_list = intersectionPlus(permissions.uneditable_related_list, po.uneditable_related_list);\n      });\n    }\n    if (object.is_view) {\n      permissions.allowCreate = false;\n      permissions.allowEdit = false;\n      permissions.allowDelete = false;\n      permissions.modifyAllRecords = false;\n      permissions.modifyCompanyRecords = false;\n      permissions.disabled_actions = [];\n    }\n    Creator.processPermissions(permissions);\n    if (object.permission_set.owner) {\n      permissions.owner = object.permission_set.owner;\n    }\n    return permissions;\n  };\n  Meteor.methods({\n    \"creator.object_permissions\": function(spaceId) {\n      return Creator.getAllPermissions(spaceId, this.userId);\n    }\n  });\n}\n","\nsteedosCore = require('@steedos/core')\n\nMeteor.startup ()->\n\tcreator_db_url = process.env.MONGO_URL_CREATOR\n\toplog_url = process.env.MONGO_OPLOG_URL_CREATOR\n\tif creator_db_url\n\t\tif !oplog_url\n\t\t\tthrow new Meteor.Error(500, \"Please configure environment variables: MONGO_OPLOG_URL_CREATOR\")\n\t\tCreator._CREATOR_DATASOURCE = {_driver: new MongoInternals.RemoteCollectionDriver(creator_db_url, {oplogUrl: oplog_url})}\n\nCreator.getCollectionName = (object)->\n#\tif object.table_name && object.table_name.endsWith(\"__c\")\n#\t\treturn object.table_name\n#\telse\n#\t\treturn object.name\n\treturn object.name\nCreator.createCollection = (object)->\n\tcollection_key = Creator.getCollectionName(object)\n\tif db[collection_key]\n\t\treturn db[collection_key]\n\telse if object.db\n\t\treturn object.db\n\n\tif Creator.Collections[collection_key]\n\t\treturn Creator.Collections[collection_key]\n\telse\n\t\tif object.custom\n\t\t\treturn steedosCore.newCollection(collection_key, Creator._CREATOR_DATASOURCE)\n\t\telse\n\t\t\tif collection_key == '_sms_queue' && SMSQueue?.collection\n\t\t\t\treturn SMSQueue.collection\n\t\t\treturn steedosCore.newCollection(collection_key)\n\n\n","var steedosCore;\n\nsteedosCore = require('@steedos/core');\n\nMeteor.startup(function() {\n  var creator_db_url, oplog_url;\n  creator_db_url = process.env.MONGO_URL_CREATOR;\n  oplog_url = process.env.MONGO_OPLOG_URL_CREATOR;\n  if (creator_db_url) {\n    if (!oplog_url) {\n      throw new Meteor.Error(500, \"Please configure environment variables: MONGO_OPLOG_URL_CREATOR\");\n    }\n    return Creator._CREATOR_DATASOURCE = {\n      _driver: new MongoInternals.RemoteCollectionDriver(creator_db_url, {\n        oplogUrl: oplog_url\n      })\n    };\n  }\n});\n\nCreator.getCollectionName = function(object) {\n  return object.name;\n};\n\nCreator.createCollection = function(object) {\n  var collection_key;\n  collection_key = Creator.getCollectionName(object);\n  if (db[collection_key]) {\n    return db[collection_key];\n  } else if (object.db) {\n    return object.db;\n  }\n  if (Creator.Collections[collection_key]) {\n    return Creator.Collections[collection_key];\n  } else {\n    if (object.custom) {\n      return steedosCore.newCollection(collection_key, Creator._CREATOR_DATASOURCE);\n    } else {\n      if (collection_key === '_sms_queue' && (typeof SMSQueue !== \"undefined\" && SMSQueue !== null ? SMSQueue.collection : void 0)) {\n        return SMSQueue.collection;\n      }\n      return steedosCore.newCollection(collection_key);\n    }\n  }\n};\n","Creator.actionsByName = {}\n\nif Meteor.isClient\n\t# 定义全局 actions 函数\t\n\tCreator.actions = (actions)->\n\t\t_.each actions, (todo, action_name)->\n\t\t\tCreator.actionsByName[action_name] = todo \n\n\tCreator.executeAction = (object_name, action, record_id, item_element, list_view_id, record, callback)->\n\t\tif action && action.type == 'word-print'\n\t\t\tif record_id\n\t\t\t\tfilters = ['_id', '=', record_id]\n\t\t\telse\n\t\t\t\tfilters = ObjectGrid.getFilters(object_name, list_view_id, false, null, null)\n\t\t\turl = \"/api/v4/word_templates/\" + action.word_template + \"/print\" + \"?filters=\" + SteedosFilters.formatFiltersToODataQuery(filters);\n\t\t\turl = Steedos.absoluteUrl(url);\n\t\t\treturn window.open(url);\n\n\t\tobj = Creator.getObject(object_name)\n\t\tif action?.todo\n\t\t\tif typeof action.todo == \"string\"\n\t\t\t\ttodo = Creator.actionsByName[action.todo]\n\t\t\telse if typeof action.todo == \"function\"\n\t\t\t\ttodo = action.todo\t\n\t\t\tif !record && object_name && record_id\n\t\t\t\trecord = Creator.odata.get(object_name, record_id)\n\t\t\tif todo\n\t\t\t\t# item_element为空时应该设置默认值（对象的name字段），否则moreArgs拿到的后续参数位置就不对\n\t\t\t\titem_element = if item_element then item_element else \"\"\n\t\t\t\tmoreArgs = Array.prototype.slice.call(arguments, 3)\n\t\t\t\ttodoArgs = [object_name, record_id].concat(moreArgs)\n\t\t\t\ttodo.apply {\n\t\t\t\t\tobject_name: object_name\n\t\t\t\t\trecord_id: record_id\n\t\t\t\t\tobject: obj\n\t\t\t\t\taction: action\n\t\t\t\t\titem_element: item_element\n\t\t\t\t\trecord: record\n\t\t\t\t}, todoArgs\n\t\t\telse\n\t\t\t\ttoastr.warning(t(\"_object_actions_none_todo\"))\n\t\telse\n\t\t\ttoastr.warning(t(\"_object_actions_none_todo\"))\n\n\n\t_deleteRecord = (object_name, record_id, record_title, list_view_id, record, call_back, call_back_error)->\n\t\t# console.log(\"===_deleteRecord===\", object_name, record_id, record_title, list_view_id, record, call_back, call_back_error);\n\t\tobject = Creator.getObject(object_name)\n\t\tpreviousDoc = FormManager.getPreviousDoc(object_name, record_id, 'delete')\n\t\tCreator.odata.delete object_name, record_id, ()->\n\t\t\tif record_title\n\t\t\t\t# info = object.label + \"\\\"#{record_title}\\\"\" + \"已删除\"\n\t\t\t\tinfo =t \"creator_record_remove_swal_title_suc\", object.label + \"\\\"#{record_title}\\\"\"\n\t\t\telse\n\t\t\t\tinfo = t('creator_record_remove_swal_suc')\n\t\t\ttoastr.success info\n\t\t\tif call_back and typeof call_back == \"function\"\n\t\t\t\tcall_back()\n\n\t\t\tFormManager.runHook(object_name, 'delete', 'after', {_id: record_id, previousDoc: previousDoc})\n\t\t, (error)->\n\t\t\tif call_back_error and typeof call_back_error == \"function\"\n\t\t\t\tcall_back_error()\n\t\t\tFormManager.runHook(object_name, 'delete', 'error', {_id: record_id, error: error})\n\n\tCreator.relatedObjectStandardNew = (related_object_name)->\n\t\trelateObject = Creator.getObject(related_object_name)\n\t\tcollection_name = relateObject.label\n\t\tcollection = \"Creator.Collections.#{Creator.getObject(related_object_name)._collection_name}\"\n\t\tcurrent_object_name = Session.get(\"object_name\")\n\t\tcurrent_record_id = Session.get(\"record_id\")\n\t\tids = Creator.TabularSelectedIds[related_object_name]\n\t\tinitialValues = {};\n\t\tif ids?.length\n\t\t\t# 列表有选中项时，取第一个选中项，复制其内容到新建窗口中\n\t\t\t# 这的第一个指的是第一次勾选的选中项，而不是列表中已勾选的第一项\n\t\t\trecord_id = ids[0]\n\t\t\tdoc = Creator.odata.get(related_object_name, record_id)\n\t\t\tinitialValues = doc\n\t\t\t# “保存并新建”操作中自动打开的新窗口中需要再次复制最新的doc内容到新窗口中\n\t\t\tSession.set 'cmShowAgainDuplicated', true\n\t\telse\n\t\t\tdefaultDoc = FormManager.getRelatedInitialValues(current_object_name, current_record_id, related_object_name);\n\t\t\tif !_.isEmpty(defaultDoc)\n\t\t\t\tinitialValues = defaultDoc\n\t\tif relateObject?.version >= 2\n\t\t\treturn SteedosUI.showModal(stores.ComponentRegistry.components.ObjectForm, {\n\t\t\t\tname: \"#{related_object_name}_standard_new_form\",\n\t\t\t\tobjectApiName: related_object_name,\n\t\t\t\ttitle: '新建 ' + relateObject.label,\n\t\t\t\tinitialValues: initialValues,\n\t\t\t\tafterInsert: (result)->\n\t\t\t\t\tsetTimeout(()->\n\t\t\t\t\t\t# ObjectForm有缓存，新建子表记录可能会有汇总字段，需要刷新表单数据\n\t\t\t\t\t\tif Creator.getObject(current_object_name).version > 1\n\t\t\t\t\t\t\tSteedosUI.reloadRecord(current_object_name, current_record_id)\n\t\t\t\t\t\tFlowRouter.reload();\n\t\t\t\t\t, 1);\n\t\t\t\t\treturn true;\n\t\t\t}, null, {iconPath: '/assets/icons'})\n\n\n\t\tif ids?.length\n\t\t\t# 列表有选中项时，取第一个选中项，复制其内容到新建窗口中\n\t\t\t# 这的第一个指的是第一次勾选的选中项，而不是列表中已勾选的第一项\n\t\t\tSession.set 'cmDoc', initialValues\n\t\t\t# “保存并新建”操作中自动打开的新窗口中需要再次复制最新的doc内容到新窗口中\n\t\t\tSession.set 'cmShowAgainDuplicated', true\n\t\telse\n\t\t\tif !_.isEmpty(initialValues)\n\t\t\t\tSession.set 'cmDoc', initialValues\n\n\t\tSession.set(\"action_fields\", undefined)\n\t\tSession.set(\"action_collection\", collection)\n\t\tSession.set(\"action_collection_name\", collection_name)\n\t\tSession.set(\"action_save_and_insert\", false)\n\t\tMeteor.defer ()->\n\t\t\t$(\".creator-add-related\").click()\n\t\treturn\n\n\tCreator.actions \n\t\t# 在此定义全局 actions\n\t\t\"standard_query\": ()->\n\t\t\tModal.show(\"standard_query_modal\")\n\n\t\t\"standard_new\": (object_name, record_id, fields)->\n\t\t\t# current_record_id = Session.get(\"record_id\")\n\t\t\t# if current_record_id\n\t\t\t# \t# amis 相关子表右上角新建\n\t\t\t# \tCreator.relatedObjectStandardNew(object_name)\n\t\t\t# \treturn \n\t\t\tobject = Creator.getObject(object_name);\n\t\t\tgridName = this.action.gridName;\n\t\t\tisRelated = this.action.isRelated;\n\t\t\tif isRelated\n\t\t\t\trelatedFieldName = this.action.relatedFieldName;\n\t\t\t\tmasterRecordId = this.action.masterRecordId;\n\t\t\t\tinitialValues = this.action.initialValues\n\t\t\t\tif !initialValues\n\t\t\t\t\tinitialValues = {};\n\t\t\t\t\tinitialValues[relatedFieldName] = masterRecordId\n\t\t\telse\n\t\t\t\tinitialValues={}\n\t\t\t\tif(gridName)\n\t\t\t\t\tselectedRows = window.gridRefs?[gridName].current?.api?.getSelectedRows()\n\t\t\t\telse\n\t\t\t\t\tselectedRows = window.gridRef?.current?.api?.getSelectedRows()\t\n\t\t\t\t\n\t\t\t\tif selectedRows?.length\n\t\t\t\t\trecord_id = selectedRows[0]._id;\n\t\t\t\t\tif record_id\n\t\t\t\t\t\tinitialValues = Creator.odata.get(object_name, record_id)\n\n\t\t\t\telse\n\t\t\t\t\tinitialValues = FormManager.getInitialValues(object_name)\n\n\t\t\tif object?.version >= 2\n\t\t\t\treturn Steedos.Page.Form.StandardNew.render(Session.get(\"app_id\"), object_name, t('New') + ' ' + object.label, initialValues , {gridName: gridName});\n\t\t\tSession.set 'action_object_name', object_name\n\t\t\tif selectedRows?.length\n\t\t\t\t# 列表有选中项时，取第一个选中项，复制其内容到新建窗口中\n\t\t\t\t# 这的第一个指的是第一次勾选的选中项，而不是列表中已勾选的第一项\n\t\t\t\tSession.set 'cmDoc', initialValues\n\t\t\t\t# “保存并新建”操作中自动打开的新窗口中需要再次复制最新的doc内容到新窗口中\n\t\t\t\tSession.set 'cmShowAgainDuplicated', true\n\t\t\telse\n\t\t\t\tSession.set 'cmDoc', initialValues\n\t\t\tMeteor.defer ()->\n\t\t\t\t$(\".creator-add\").click()\n\t\t\treturn \n\n\t\t\"standard_open_view\": (object_name, record_id, fields)->\n\t\t\thref = Creator.getObjectUrl(object_name, record_id)\n\t\t\tFlowRouter.redirect(href)\n\t\t\treturn false\n\n\t\t\"standard_edit\": (object_name, record_id, fields)->\n\t\t\tif record_id\n\t\t\t\tobject = Creator.getObject(object_name);\n\t\t\t\tif object?.version >= 2\n\t\t\t\t\treturn Steedos.Page.Form.StandardEdit.render(Session.get(\"app_id\"), object_name, t('Edit') + ' ' + object.label, record_id, {\n\t\t\t\t\t\tgridName: this.action.gridName\n\t\t\t\t\t})\n\t\t\t\tif Steedos.isMobile() && false\n#\t\t\t\t\trecord = Creator.getObjectRecord(object_name, record_id)\n#\t\t\t\t\tSession.set 'cmDoc', record\n#\t\t\t\t\tSession.set 'reload_dxlist', false\n\t\t\t\t\tSession.set 'action_object_name', object_name\n\t\t\t\t\tSession.set 'action_record_id', record_id\n\t\t\t\t\tif this.record\n\t\t\t\t\t\tSession.set 'cmDoc', this.record\n\t\t\t\t\tMeteor.defer ()->\n\t\t\t\t\t\t$(\".btn-edit-record\").click()\n\t\t\t\telse\n\t\t\t\t\tSession.set 'action_object_name', object_name\n\t\t\t\t\tSession.set 'action_record_id', record_id\n\t\t\t\t\tif this.record\n\t\t\t\t\t\tSession.set 'cmDoc', this.record\n\t\t\t\t\t\tMeteor.defer ()->\n\t\t\t\t\t\t\t$(\".btn.creator-edit\").click()\n\n\t\t\"standard_delete\": (object_name, record_id, record_title, list_view_id, record, call_back)->\n\t\t\tgridName = this.action.gridName;\n\t\t\t# console.log(\"===standard_delete===\", object_name, record_id, record_title, list_view_id, record, call_back);\n\t\t\tif record_id\n\t\t\t\tbeforeHook = FormManager.runHook(object_name, 'delete', 'before', {_id: record_id})\n\t\t\t\tif !beforeHook\n\t\t\t\t\treturn false;\n\t\t\tobject = Creator.getObject(object_name)\n\t\t\tnameField = object.NAME_FIELD_KEY || \"name\"\n\n\t\t\tunless list_view_id\n\t\t\t\tlist_view_id = Session.get(\"list_view_id\")\n\t\t\tunless list_view_id\n\t\t\t\tlist_view_id = \"all\"\n\n\t\t\tif(!_.isString(record_title) && record_title)\n\t\t\t\trecord_title = record_title[nameField]\n\t\t\t\n\t\t\tif record && !record_title\n\t\t\t\trecord_title = record[nameField]\n\t\t\t\n\t\t\ti18nTitleKey = \"creator_record_remove_swal_title\"\n\t\t\ti18nTextKey = \"creator_record_remove_swal_text\"\n\n\t\t\tunless record_id\n\t\t\t\ti18nTitleKey = \"creator_record_remove_many_swal_title\"\n\t\t\t\ti18nTextKey = \"creator_record_remove_many_swal_text\"\n\n\t\t\t\t# 如果是批量删除，则传入的list_view_id为列表视图的name，用于获取列表选中项\n\t\t\t\t# 主列表规则是\"listview_#{object_name}_#{list_view_id}\"，相关表规则是\"related_listview_#{object_name}_#{related_object_name}_#{related_field_name}\"\n\t\t\t\tselectedRecords = SteedosUI.getTableSelectedRows(gridName || list_view_id)\n\t\t\t\tif !selectedRecords || !selectedRecords.length\n\t\t\t\t\ttoastr.warning(t(\"creator_record_remove_many_no_selection\"))\n\t\t\t\t\treturn\n\n\t\t\tif record_title\n\t\t\t\ttext = t i18nTextKey, \"#{object.label} \\\"#{record_title}\\\"\"\n\t\t\telse\n\t\t\t\ttext = t i18nTextKey, \"#{object.label}\"\n\t\t\tswal\n\t\t\t\ttitle: t i18nTitleKey, \"#{object.label}\"\n\t\t\t\ttext: \"<div class='delete-creator-warning'>#{text}</div>\"\n\t\t\t\thtml: true\n\t\t\t\tshowCancelButton:true\n\t\t\t\tconfirmButtonText: t('Delete')\n\t\t\t\tcancelButtonText: t('Cancel')\n\t\t\t\t(option) ->\n\t\t\t\t\tif option\n\t\t\t\t\t\tif record_id\n\t\t\t\t\t\t\t# 单条记录删除\n\t\t\t\t\t\t\t_deleteRecord object_name, record_id, record_title, list_view_id, record, ()->\n\t\t\t\t\t\t\t\t# 文件版本为\"cfs.files.filerecord\"，需要替换为\"cfs-files-filerecord\"\n\t\t\t\t\t\t\t\tgridObjectNameClass = object_name.replace(/\\./g,\"-\")\n\t\t\t\t\t\t\t\tgridContainer = $(\".gridContainer.#{gridObjectNameClass}\")\n\t\t\t\t\t\t\t\tunless gridContainer?.length\n\t\t\t\t\t\t\t\t\tif window.opener\n\t\t\t\t\t\t\t\t\t\tisOpenerRemove = false\n\t\t\t\t\t\t\t\t\t\tgridContainer = window.opener.$(\".gridContainer.#{gridObjectNameClass}\")\n\t\t\t\t\t\t\t\ttry\n\t\t\t\t\t\t\t\t\t# ObjectForm有缓存，删除子表记录可能会有汇总字段，需要刷新表单数据\n\t\t\t\t\t\t\t\t\tcurrent_object_name = Session.get(\"object_name\")\n\t\t\t\t\t\t\t\t\tcurrent_record_id = Session.get(\"record_id\")\n\t\t\t\t\t\t\t\t\tif current_object_name && Creator.getObject(current_object_name)?.version > 1\n\t\t\t\t\t\t\t\t\t\tSteedosUI.reloadRecord(current_object_name, current_record_id)\n\t\t\t\t\t\t\t\t\tif FlowRouter.current().route.path.endsWith(\"/:record_id\")\n\t\t\t\t\t\t\t\t\t\tif object_name != Session.get(\"object_name\")\n\t\t\t\t\t\t\t\t\t\t\tFlowRouter.reload();\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\twindow.refreshGrid(gridName);\n\t\t\t\t\t\t\t\tcatch _e\n\t\t\t\t\t\t\t\t\tconsole.error(_e);\n\t\t\t\t\t\t\t\tif gridContainer?.length\n\t\t\t\t\t\t\t\t\tif object.enable_tree\n\t\t\t\t\t\t\t\t\t\tdxDataGridInstance = gridContainer.dxTreeList().dxTreeList('instance')\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tdxDataGridInstance = gridContainer.dxDataGrid().dxDataGrid('instance')\n\t\t\t\t\t\t\t\tif dxDataGridInstance\n\t\t\t\t\t\t\t\t\tif object.enable_tree\n\t\t\t\t\t\t\t\t\t\tdxDataGridInstance.refresh()\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tif object_name != Session.get(\"object_name\")\n\t\t\t\t\t\t\t\t\t\t\tFlowRouter.reload();\n\t\t\t\t\t\t\t\t\t\t# else\n\t\t\t\t\t\t\t\t\t\t# \tTemplate.creator_grid.refresh(dxDataGridInstance)\n\t\t\t\t\t\t\t\trecordUrl = Creator.getObjectUrl(object_name, record_id)\n\t\t\t\t\t\t\t\ttempNavRemoved = Creator.removeTempNavItem(object_name, recordUrl) #无论是在记录详细界面还是列表界面执行删除操作，都会把临时导航删除掉\n\t\t\t\t\t\t\t\tif isOpenerRemove or !dxDataGridInstance\n\t\t\t\t\t\t\t\t\tif isOpenerRemove\n\t\t\t\t\t\t\t\t\t\twindow.close()\n\t\t\t\t\t\t\t\t\telse if record_id == Session.get(\"record_id\") and list_view_id != 'calendar'\n\t\t\t\t\t\t\t\t\t\tappid = Session.get(\"app_id\")\n\t\t\t\t\t\t\t\t\t\tunless tempNavRemoved\n\t\t\t\t\t\t\t\t\t\t\t# 如果确实删除了临时导航，就可能已经重定向到上一个页面了，没必要再重定向一次\n\t\t\t\t\t\t\t\t\t\t\tFlowRouter.go \"/app/#{appid}/#{object_name}/grid/#{list_view_id}\"\n\t\t\t\t\t\t\t\tif call_back and typeof call_back == \"function\"\n\t\t\t\t\t\t\t\t\tcall_back()\t\t\t\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t# 批量删除\n\t\t\t\t\t\t\tif selectedRecords && selectedRecords.length\n\t\t\t\t\t\t\t\t$(\"body\").addClass(\"loading\")\n\t\t\t\t\t\t\t\tdeleteCounter = 0;\n\t\t\t\t\t\t\t\tafterBatchesDelete = ()->\n\t\t\t\t\t\t\t\t\tdeleteCounter++\n\t\t\t\t\t\t\t\t\tif deleteCounter >= selectedRecords.length\n\t\t\t\t\t\t\t\t\t\t# console.log(\"deleteCounter, selectedRecords.length===\", deleteCounter, selectedRecords.length);\n\t\t\t\t\t\t\t\t\t\t$(\"body\").removeClass(\"loading\")\n\t\t\t\t\t\t\t\t\t\twindow.refreshGrid(gridName);\n\t\t\t\t\t\t\t\tselectedRecords.forEach (record)->\n\t\t\t\t\t\t\t\t\trecord_id = record._id\n\t\t\t\t\t\t\t\t\tbeforeHook = FormManager.runHook(object_name, 'delete', 'before', {_id: record_id})\n\t\t\t\t\t\t\t\t\tif !beforeHook\n\t\t\t\t\t\t\t\t\t\tafterBatchesDelete()\n\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\trecordTitle = record[nameField] || record_id\n\t\t\t\t\t\t\t\t\t_deleteRecord object_name, record._id, recordTitle, list_view_id, record, (()->\n\t\t\t\t\t\t\t\t\t\trecordUrl = Creator.getObjectUrl(object_name, record_id)\n\t\t\t\t\t\t\t\t\t\tCreator.removeTempNavItem(object_name, recordUrl) #无论是在记录详细界面还是列表界面执行删除操作，都会把临时导航删除掉\n\t\t\t\t\t\t\t\t\t\tafterBatchesDelete()\n\t\t\t\t\t\t\t\t\t), ()->\n\t\t\t\t\t\t\t\t\t\tafterBatchesDelete()","var _deleteRecord;\n\nCreator.actionsByName = {};\n\nif (Meteor.isClient) {\n  Creator.actions = function(actions) {\n    return _.each(actions, function(todo, action_name) {\n      return Creator.actionsByName[action_name] = todo;\n    });\n  };\n  Creator.executeAction = function(object_name, action, record_id, item_element, list_view_id, record, callback) {\n    var filters, moreArgs, obj, todo, todoArgs, url;\n    if (action && action.type === 'word-print') {\n      if (record_id) {\n        filters = ['_id', '=', record_id];\n      } else {\n        filters = ObjectGrid.getFilters(object_name, list_view_id, false, null, null);\n      }\n      url = \"/api/v4/word_templates/\" + action.word_template + \"/print\" + \"?filters=\" + SteedosFilters.formatFiltersToODataQuery(filters);\n      url = Steedos.absoluteUrl(url);\n      return window.open(url);\n    }\n    obj = Creator.getObject(object_name);\n    if (action != null ? action.todo : void 0) {\n      if (typeof action.todo === \"string\") {\n        todo = Creator.actionsByName[action.todo];\n      } else if (typeof action.todo === \"function\") {\n        todo = action.todo;\n      }\n      if (!record && object_name && record_id) {\n        record = Creator.odata.get(object_name, record_id);\n      }\n      if (todo) {\n        item_element = item_element ? item_element : \"\";\n        moreArgs = Array.prototype.slice.call(arguments, 3);\n        todoArgs = [object_name, record_id].concat(moreArgs);\n        return todo.apply({\n          object_name: object_name,\n          record_id: record_id,\n          object: obj,\n          action: action,\n          item_element: item_element,\n          record: record\n        }, todoArgs);\n      } else {\n        return toastr.warning(t(\"_object_actions_none_todo\"));\n      }\n    } else {\n      return toastr.warning(t(\"_object_actions_none_todo\"));\n    }\n  };\n  _deleteRecord = function(object_name, record_id, record_title, list_view_id, record, call_back, call_back_error) {\n    var object, previousDoc;\n    object = Creator.getObject(object_name);\n    previousDoc = FormManager.getPreviousDoc(object_name, record_id, 'delete');\n    return Creator.odata[\"delete\"](object_name, record_id, function() {\n      var info;\n      if (record_title) {\n        info = t(\"creator_record_remove_swal_title_suc\", object.label + (\"\\\"\" + record_title + \"\\\"\"));\n      } else {\n        info = t('creator_record_remove_swal_suc');\n      }\n      toastr.success(info);\n      if (call_back && typeof call_back === \"function\") {\n        call_back();\n      }\n      return FormManager.runHook(object_name, 'delete', 'after', {\n        _id: record_id,\n        previousDoc: previousDoc\n      });\n    }, function(error) {\n      if (call_back_error && typeof call_back_error === \"function\") {\n        call_back_error();\n      }\n      return FormManager.runHook(object_name, 'delete', 'error', {\n        _id: record_id,\n        error: error\n      });\n    });\n  };\n  Creator.relatedObjectStandardNew = function(related_object_name) {\n    var collection, collection_name, current_object_name, current_record_id, defaultDoc, doc, ids, initialValues, record_id, relateObject;\n    relateObject = Creator.getObject(related_object_name);\n    collection_name = relateObject.label;\n    collection = \"Creator.Collections.\" + (Creator.getObject(related_object_name)._collection_name);\n    current_object_name = Session.get(\"object_name\");\n    current_record_id = Session.get(\"record_id\");\n    ids = Creator.TabularSelectedIds[related_object_name];\n    initialValues = {};\n    if (ids != null ? ids.length : void 0) {\n      record_id = ids[0];\n      doc = Creator.odata.get(related_object_name, record_id);\n      initialValues = doc;\n      Session.set('cmShowAgainDuplicated', true);\n    } else {\n      defaultDoc = FormManager.getRelatedInitialValues(current_object_name, current_record_id, related_object_name);\n      if (!_.isEmpty(defaultDoc)) {\n        initialValues = defaultDoc;\n      }\n    }\n    if ((relateObject != null ? relateObject.version : void 0) >= 2) {\n      return SteedosUI.showModal(stores.ComponentRegistry.components.ObjectForm, {\n        name: related_object_name + \"_standard_new_form\",\n        objectApiName: related_object_name,\n        title: '新建 ' + relateObject.label,\n        initialValues: initialValues,\n        afterInsert: function(result) {\n          setTimeout(function() {\n            if (Creator.getObject(current_object_name).version > 1) {\n              SteedosUI.reloadRecord(current_object_name, current_record_id);\n            }\n            return FlowRouter.reload();\n          }, 1);\n          return true;\n        }\n      }, null, {\n        iconPath: '/assets/icons'\n      });\n    }\n    if (ids != null ? ids.length : void 0) {\n      Session.set('cmDoc', initialValues);\n      Session.set('cmShowAgainDuplicated', true);\n    } else {\n      if (!_.isEmpty(initialValues)) {\n        Session.set('cmDoc', initialValues);\n      }\n    }\n    Session.set(\"action_fields\", void 0);\n    Session.set(\"action_collection\", collection);\n    Session.set(\"action_collection_name\", collection_name);\n    Session.set(\"action_save_and_insert\", false);\n    Meteor.defer(function() {\n      return $(\".creator-add-related\").click();\n    });\n  };\n  Creator.actions({\n    \"standard_query\": function() {\n      return Modal.show(\"standard_query_modal\");\n    },\n    \"standard_new\": function(object_name, record_id, fields) {\n      var gridName, initialValues, isRelated, masterRecordId, object, ref, ref1, ref2, ref3, ref4, ref5, relatedFieldName, selectedRows;\n      object = Creator.getObject(object_name);\n      gridName = this.action.gridName;\n      isRelated = this.action.isRelated;\n      if (isRelated) {\n        relatedFieldName = this.action.relatedFieldName;\n        masterRecordId = this.action.masterRecordId;\n        initialValues = this.action.initialValues;\n        if (!initialValues) {\n          initialValues = {};\n          initialValues[relatedFieldName] = masterRecordId;\n        }\n      } else {\n        initialValues = {};\n        if (gridName) {\n          selectedRows = (ref = window.gridRefs) != null ? (ref1 = ref[gridName].current) != null ? (ref2 = ref1.api) != null ? ref2.getSelectedRows() : void 0 : void 0 : void 0;\n        } else {\n          selectedRows = (ref3 = window.gridRef) != null ? (ref4 = ref3.current) != null ? (ref5 = ref4.api) != null ? ref5.getSelectedRows() : void 0 : void 0 : void 0;\n        }\n        if (selectedRows != null ? selectedRows.length : void 0) {\n          record_id = selectedRows[0]._id;\n          if (record_id) {\n            initialValues = Creator.odata.get(object_name, record_id);\n          }\n        } else {\n          initialValues = FormManager.getInitialValues(object_name);\n        }\n      }\n      if ((object != null ? object.version : void 0) >= 2) {\n        return Steedos.Page.Form.StandardNew.render(Session.get(\"app_id\"), object_name, t('New') + ' ' + object.label, initialValues, {\n          gridName: gridName\n        });\n      }\n      Session.set('action_object_name', object_name);\n      if (selectedRows != null ? selectedRows.length : void 0) {\n        Session.set('cmDoc', initialValues);\n        Session.set('cmShowAgainDuplicated', true);\n      } else {\n        Session.set('cmDoc', initialValues);\n      }\n      Meteor.defer(function() {\n        return $(\".creator-add\").click();\n      });\n    },\n    \"standard_open_view\": function(object_name, record_id, fields) {\n      var href;\n      href = Creator.getObjectUrl(object_name, record_id);\n      FlowRouter.redirect(href);\n      return false;\n    },\n    \"standard_edit\": function(object_name, record_id, fields) {\n      var object;\n      if (record_id) {\n        object = Creator.getObject(object_name);\n        if ((object != null ? object.version : void 0) >= 2) {\n          return Steedos.Page.Form.StandardEdit.render(Session.get(\"app_id\"), object_name, t('Edit') + ' ' + object.label, record_id, {\n            gridName: this.action.gridName\n          });\n        }\n        if (Steedos.isMobile() && false) {\n          Session.set('action_object_name', object_name);\n          Session.set('action_record_id', record_id);\n          if (this.record) {\n            Session.set('cmDoc', this.record);\n          }\n          return Meteor.defer(function() {\n            return $(\".btn-edit-record\").click();\n          });\n        } else {\n          Session.set('action_object_name', object_name);\n          Session.set('action_record_id', record_id);\n          if (this.record) {\n            Session.set('cmDoc', this.record);\n            return Meteor.defer(function() {\n              return $(\".btn.creator-edit\").click();\n            });\n          }\n        }\n      }\n    },\n    \"standard_delete\": function(object_name, record_id, record_title, list_view_id, record, call_back) {\n      var beforeHook, gridName, i18nTextKey, i18nTitleKey, nameField, object, selectedRecords, text;\n      gridName = this.action.gridName;\n      if (record_id) {\n        beforeHook = FormManager.runHook(object_name, 'delete', 'before', {\n          _id: record_id\n        });\n        if (!beforeHook) {\n          return false;\n        }\n      }\n      object = Creator.getObject(object_name);\n      nameField = object.NAME_FIELD_KEY || \"name\";\n      if (!list_view_id) {\n        list_view_id = Session.get(\"list_view_id\");\n      }\n      if (!list_view_id) {\n        list_view_id = \"all\";\n      }\n      if (!_.isString(record_title) && record_title) {\n        record_title = record_title[nameField];\n      }\n      if (record && !record_title) {\n        record_title = record[nameField];\n      }\n      i18nTitleKey = \"creator_record_remove_swal_title\";\n      i18nTextKey = \"creator_record_remove_swal_text\";\n      if (!record_id) {\n        i18nTitleKey = \"creator_record_remove_many_swal_title\";\n        i18nTextKey = \"creator_record_remove_many_swal_text\";\n        selectedRecords = SteedosUI.getTableSelectedRows(gridName || list_view_id);\n        if (!selectedRecords || !selectedRecords.length) {\n          toastr.warning(t(\"creator_record_remove_many_no_selection\"));\n          return;\n        }\n      }\n      if (record_title) {\n        text = t(i18nTextKey, object.label + \" \\\"\" + record_title + \"\\\"\");\n      } else {\n        text = t(i18nTextKey, \"\" + object.label);\n      }\n      return swal({\n        title: t(i18nTitleKey, \"\" + object.label),\n        text: \"<div class='delete-creator-warning'>\" + text + \"</div>\",\n        html: true,\n        showCancelButton: true,\n        confirmButtonText: t('Delete'),\n        cancelButtonText: t('Cancel')\n      }, function(option) {\n        var afterBatchesDelete, deleteCounter;\n        if (option) {\n          if (record_id) {\n            return _deleteRecord(object_name, record_id, record_title, list_view_id, record, function() {\n              var _e, appid, current_object_name, current_record_id, dxDataGridInstance, gridContainer, gridObjectNameClass, isOpenerRemove, recordUrl, ref, tempNavRemoved;\n              gridObjectNameClass = object_name.replace(/\\./g, \"-\");\n              gridContainer = $(\".gridContainer.\" + gridObjectNameClass);\n              if (!(gridContainer != null ? gridContainer.length : void 0)) {\n                if (window.opener) {\n                  isOpenerRemove = false;\n                  gridContainer = window.opener.$(\".gridContainer.\" + gridObjectNameClass);\n                }\n              }\n              try {\n                current_object_name = Session.get(\"object_name\");\n                current_record_id = Session.get(\"record_id\");\n                if (current_object_name && ((ref = Creator.getObject(current_object_name)) != null ? ref.version : void 0) > 1) {\n                  SteedosUI.reloadRecord(current_object_name, current_record_id);\n                }\n                if (FlowRouter.current().route.path.endsWith(\"/:record_id\")) {\n                  if (object_name !== Session.get(\"object_name\")) {\n                    FlowRouter.reload();\n                  }\n                } else {\n                  window.refreshGrid(gridName);\n                }\n              } catch (error1) {\n                _e = error1;\n                console.error(_e);\n              }\n              if (gridContainer != null ? gridContainer.length : void 0) {\n                if (object.enable_tree) {\n                  dxDataGridInstance = gridContainer.dxTreeList().dxTreeList('instance');\n                } else {\n                  dxDataGridInstance = gridContainer.dxDataGrid().dxDataGrid('instance');\n                }\n              }\n              if (dxDataGridInstance) {\n                if (object.enable_tree) {\n                  dxDataGridInstance.refresh();\n                } else {\n                  if (object_name !== Session.get(\"object_name\")) {\n                    FlowRouter.reload();\n                  }\n                }\n              }\n              recordUrl = Creator.getObjectUrl(object_name, record_id);\n              tempNavRemoved = Creator.removeTempNavItem(object_name, recordUrl);\n              if (isOpenerRemove || !dxDataGridInstance) {\n                if (isOpenerRemove) {\n                  window.close();\n                } else if (record_id === Session.get(\"record_id\") && list_view_id !== 'calendar') {\n                  appid = Session.get(\"app_id\");\n                  if (!tempNavRemoved) {\n                    FlowRouter.go(\"/app/\" + appid + \"/\" + object_name + \"/grid/\" + list_view_id);\n                  }\n                }\n              }\n              if (call_back && typeof call_back === \"function\") {\n                return call_back();\n              }\n            });\n          } else {\n            if (selectedRecords && selectedRecords.length) {\n              $(\"body\").addClass(\"loading\");\n              deleteCounter = 0;\n              afterBatchesDelete = function() {\n                deleteCounter++;\n                if (deleteCounter >= selectedRecords.length) {\n                  $(\"body\").removeClass(\"loading\");\n                  return window.refreshGrid(gridName);\n                }\n              };\n              return selectedRecords.forEach(function(record) {\n                var recordTitle;\n                record_id = record._id;\n                beforeHook = FormManager.runHook(object_name, 'delete', 'before', {\n                  _id: record_id\n                });\n                if (!beforeHook) {\n                  afterBatchesDelete();\n                  return;\n                }\n                recordTitle = record[nameField] || record_id;\n                return _deleteRecord(object_name, record._id, recordTitle, list_view_id, record, (function() {\n                  var recordUrl;\n                  recordUrl = Creator.getObjectUrl(object_name, record_id);\n                  Creator.removeTempNavItem(object_name, recordUrl);\n                  return afterBatchesDelete();\n                }), function() {\n                  return afterBatchesDelete();\n                });\n              });\n            }\n          }\n        }\n      });\n    }\n  });\n}\n"]} +//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["meteor://💻app/packages/steedos_objects/core.coffee","meteor://💻app/core.coffee","meteor://💻app/packages/steedos_objects/loadStandardObjects.coffee","meteor://💻app/loadStandardObjects.coffee","meteor://💻app/packages/steedos_objects/coreSupport.coffee","meteor://💻app/coreSupport.coffee","meteor://💻app/packages/steedos_objects/server/methods/object_options.coffee","meteor://💻app/server/methods/object_options.coffee","meteor://💻app/packages/steedos_objects/lib/listviews.coffee","meteor://💻app/lib/listviews.coffee","meteor://💻app/packages/steedos_objects/lib/add_simple_schema_validation_error.coffee","meteor://💻app/lib/add_simple_schema_validation_error.coffee","meteor://💻app/packages/steedos_objects/lib/field_simple_schema_validation_error.coffee","meteor://💻app/lib/field_simple_schema_validation_error.coffee","meteor://💻app/packages/steedos:objects/lib/eval.js","meteor://💻app/packages/steedos_objects/lib/convert.coffee","meteor://💻app/lib/convert.coffee","meteor://💻app/packages/steedos_objects/lib/formular.coffee","meteor://💻app/lib/formular.coffee","meteor://💻app/packages/steedos_objects/lib/object.coffee","meteor://💻app/lib/object.coffee","meteor://💻app/packages/steedos_objects/lib/fields.coffee","meteor://💻app/lib/fields.coffee","meteor://💻app/packages/steedos_objects/lib/triggers.coffee","meteor://💻app/lib/triggers.coffee","meteor://💻app/packages/steedos_objects/lib/permission_sets.coffee","meteor://💻app/lib/permission_sets.coffee","meteor://💻app/packages/steedos_objects/lib/collections.coffee","meteor://💻app/lib/collections.coffee","meteor://💻app/packages/steedos_objects/lib/actions.coffee","meteor://💻app/lib/actions.coffee"],"names":["db","Creator","Objects","Collections","Menus","Apps","Dashboards","Reports","subs","steedosSchema","APIService","MetadataService","config","e","moleculer","objectql","packageLoader","packageService","path","settings","steedosCore","process","env","CREATOR_NODE_ENV","require","getSteedosConfig","built_in_plugins","plugins","Meteor","startup","apiService","broker","ex","metadataService","objectqlService","pageService","projectService","standardObjectsDir","standardObjectsPackageLoaderService","steedosService","uiService","ServiceBroker","namespace","nodeID","metadata","transporter","TRANSPORTER","cacher","CACHER","logLevel","serializer","requestTimeout","maxCallLevel","heartbeatInterval","heartbeatTimeout","contextParamsCloning","tracking","enabled","shutdownTimeout","disableBalancer","registry","strategy","preferLocal","bulkhead","concurrency","maxQueueSize","validator","errorHandler","tracing","exporter","type","options","logger","colors","width","gaugeWidth","skipProcessEventRegistration","created","warn","clean","init","createService","name","mixins","port","started","setTimeout","emit","getSteedosSchema","StandardObjectsPath","packageInfo","wrapAsync","cb","start","then","connectHandlersExpress","express","_restartService","use","staticRouter","waitForServices","console","log","SteedosApi","WebApp","connectHandlers","resolve","reject","error","Fiber","deps","app","Tracker","Dependency","object","_TEMPLATE","SimpleSchema","extendOptions","filtersFunction","Match","Optional","OneOf","Function","String","optionsFunction","createFunction","isServer","fiberLoadObjects","obj","object_name","loadObjects","run","list_views","space","getCollectionName","_","clone","convertObject","Object","initTriggers","initListViews","getObjectName","getObject","space_id","ref","ref1","isArray","isClient","depend","Session","get","objectsByName","getObjectById","object_id","findWhere","_id","removeObject","getCollection","spaceId","_collection_name","removeCollection","isSpaceAdmin","userId","findOne","fields","admins","indexOf","evaluateFormula","formular","context","isString","Formular","checkFormula","evaluateFilters","filters","selector","each","filter","action","value","length","isCommonSpace","getOrderlySetByIds","docs","ids","id_key","hit_first","values","getProperty","sortBy","doc","_index","v","sortingMethod","value1","value2","isValue1Empty","isValue2Empty","locale","key","Date","getTime","Steedos","toString","localeCompare","getObjectRelateds","_object","permissions","relatedList","relatedListMap","related_objects","isEmpty","objName","isObject","objectName","related_object","related_object_name","related_field","related_field_name","reference_to","foreign_key","write_requires_master_read","enableObjName","getPermissions","enable_audit","modifyAllRecords","enable_files","push","sfsFilesObject","splice","enable_tasks","enable_notes","enable_events","enable_instances","enable_approvals","enable_process","getUserContext","isUnSafeMode","USER_CONTEXT","space_user_org","su","suFields","Error","mobile","position","email","company","organization","company_id","company_ids","user","fullname","getRelativeUrl","url","isFunction","isCordova","startsWith","test","__meteor_runtime_config__","ROOT_URL_PATH_PREFIX","getUserCompanyId","getUserCompanyIds","processPermissions","po","allowCreate","allowRead","allowEdit","allowDelete","viewAllRecords","viewCompanyRecords","modifyCompanyRecords","allowReadFiles","viewAllFiles","allowCreateFiles","allowEditFiles","allowDeleteFiles","modifyAllFiles","getTemplateSpaceId","templateSpaceId","getCloudAdminSpaceId","cloudAdminSpaceId","isTemplateSpace","isCloudAdminSpace","steedosStorageDir","STEEDOS_STORAGE_DIR","methods","collection","name_field_key","options_limit","query","query_options","records","results","searchTextQuery","selected","sort","params","NAME_FIELD_KEY","searchText","$regex","$or","$in","extend","$nin","filterQuery","limit","find","fetch","record","label","message","JSON","stringify","getInitWidthPercent","columns","_schema","column_num","init_width_percent","getSchema","field_name","field","is_wide","ref2","pick","autoform","getFieldIsWide","getTabularOrder","list_view_id","setting","record_id","map","column","hidden","compact","order","index","default_extra_columns","extra_columns","getObjectDefaultColumns","getObjectDefaultExtraColumns","union","getObjectDefaultSort","TabularSelectedIds","convertListView","default_view","list_view","list_view_name","default_columns","default_mobile_columns","oitem","mobile_columns","has","include","filter_scope","parse","forEach","_value","getRelatedList","layoutRelatedList","list","mapList","objectLayoutRelatedListObjects","relatedListNames","relatedListObjects","related_object_names","unrelated_objects","related_lists","item","reFieldName","reObjectName","related","related_field_fullname","split","field_names","is_file","customRelatedListObject","actions","buttons","visible_on","page_size","objOrName","getRelatedObjects","related_object_item","relatedObject","tabular_order","getObjectFirstListViewColumns","without","transformSortToTabular","replace","pluck","difference","isActive","allow_relatedList","getObjectFirstListView","first","getListViews","getListView","exac","listViews","getListViewIsRecent","listView","pickObjectMobileColumns","count","getField","isNameColumn","itemCount","maxCount","maxRows","nameColumn","nameKey","result","getObjectDefaultView","defaultView","use_mobile_columns","isAllView","isRecentView","tabularColumns","tabular_sort","column_index","transformSortToDX","dx_sort","RegEx","code","RegExp","_regExMessages","_globalMessages","regEx","exp","msg","messages","evalInContext","js","eval","call","convertField","getOption","option","foo","color","allOptions","picklist","picklistOptions","getPicklist","getPickListOptions","reverse","enable","defaultValue","triggers","trigger","_todo","_todo_from_code","_todo_from_db","on","todo","systemBaseFields","omit","required","readonly","getSystemBaseFields","_visible","error1","actionsByName","trim","isExpression","visible","record_permissions","globalData","assign","now","parseSingleExpression","_options","_type","beforeOpenFunction","is_company_limited","max","min","_option","k","_regEx","_min","_max","Number","Boolean","_optionsFunction","_reference_to","_createFunction","_beforeOpenFunction","_filtersFunction","_defaultValue","_is_company_limited","_filters","isDate","pop","_is_date","form","val","relatedObjInfo","PREFIX","_prependPrefixForFormula","prefix","fieldVariable","reg","rev","m","$1","formula_str","_CONTEXT","_VALUES","data","isBoolean","toastr","formatObjectName","_baseObject","_db","defaultListViewId","disabled_list_views","ref3","schema","self","baseObject","permission_set","icon","description","is_view","hasImportTemplates","version","is_enable","allow_customActions","exclude_actions","enable_search","paging","enable_api","custom","enable_share","enable_tree","sidebar","open_window","filter_company","calendar","enable_chatter","enable_trash","enable_space_global","enable_follow","enable_workflow","enable_inline_edit","details","masters","lookup_details","in_development","idFieldName","database_name","is_name","primary","filterable","item_name","copyItem","admin","all","list_view_item","ReactiveVar","createCollection","_name","getObjectSchema","contains","attachSchema","_simpleSchema","getObjectODataRouterPrefix","bootstrapLoaded","getSelectOptions","fieldSchema","data_type","optionItem","fieldsArr","_ref_obj","autoform_type","collectionName","fs","fsType","isUnLimited","multiple","rows","language","isMobile","isPad","isiOS","afFieldInput","timezoneId","dxDateBoxOptions","displayFormat","pickerType","dateMobileOptions","outFormat","showIcon","dependOn","depend_on","create","lookup_field","Modal","show","formId","operation","onSuccess","addItems","reference_sort","optionsSort","reference_limit","optionsLimit","reference_to_field","referenceToField","blackbox","objectSwitche","optionsMethod","optionsMethodParams","references","_reference","link","defaultIcon","firstOption","decimal","precision","scale","disabled","Array","editable","accept","system","Email","isNumber","optional","unique","group","searchable","inlineHelpText","isProduction","sortable","getFieldDisplayValue","field_value","html","moment","format","checkFieldTypeSupportBetweenQuery","field_type","includes","pushBetweenBuiltinOptionals","operations","builtinValues","getBetweenBuiltinValues","builtinItem","is_check_only","getBetweenTimeBuiltinValues","getBetweenBuiltinValueItem","getBetweenTimeBuiltinValueItem","getBetweenBuiltinOperation","betweenBuiltinValues","getQuarterStartMonth","month","getMonth","getLastQuarterFirstDay","year","getFullYear","getNextQuarterFirstDay","getMonthDays","days","endDate","millisecond","startDate","getLastMonthFirstDay","currentMonth","currentYear","endValue","firstDay","lastDay","lastMonday","lastMonthFinalDay","lastMonthFirstDay","lastQuarterEndDay","lastQuarterStartDay","lastSunday","last_120_days","last_30_days","last_60_days","last_7_days","last_90_days","minusDay","monday","nextMonday","nextMonthFinalDay","nextMonthFirstDay","nextQuarterEndDay","nextQuarterStartDay","nextSunday","nextYear","next_120_days","next_30_days","next_60_days","next_7_days","next_90_days","previousYear","startValue","strEndDay","strFirstDay","strLastDay","strMonday","strStartDay","strSunday","strToday","strTomorrow","strYestday","sunday","thisQuarterEndDay","thisQuarterStartDay","tomorrow","week","yestday","getDay","t","fv","setHours","getHours","getTimezoneOffset","getFieldDefaultOperation","getFieldOperation","optionals","equal","unequal","less_than","greater_than","less_or_equal","greater_or_equal","not_contain","starts_with","between","getObjectFieldsName","fieldsName","sort_no","cleanTrigger","initTrigger","_trigger_hooks","ref4","ref5","todoWrapper","apply","arguments","when","before","insert","update","remove","after","_hook","trigger_name","_trigger_hook","baseBooleanPermissionPropNames","extendPermissionProps","findOne_permission_object","find_permission_object","intersectionPlus","otherPermissionPropNames","overlayBaseBooleanPermissionProps","permissionPropNames","unionPermissionObjects","unionPlus","getObjectPermissions","getRecordPermissions","isOwner","masterObjectName","masterRecordPerm","record_company_id","record_company_ids","user_company_ids","owner","parent","n","intersection","locked","getRecordRelatedListPermissions","currentObjectName","relatedListItem","currentRecord","isRelateObjectUneditable","masterAllow","relatedObjectPermissions","uneditable_related_list","getObjectRecord","getRecordSafeRelatedList","getAllPermissions","_i","psets","psetsAdmin","psetsAdmin_pos","psetsCurrent","psetsCurrentNames","psetsCurrent_pos","psetsCustomer","psetsCustomer_pos","psetsGuest","psetsGuest_pos","psetsMember","psetsMember_pos","psetsSupplier","psetsSupplier_pos","psetsUser","psetsUser_pos","set_ids","spaceUser","objects","assigned_apps","profile","users","permission_set_id","modified","created_by","modified_by","getAssignedApps","bind","assigned_menus","getAssignedMenus","user_permission_sets","array","other","target","props","filesProNames","propNames","propName","apps","psetBase","userProfile","pset","uniq","aboutMenu","adminMenus","allMenus","currentPsetNames","menus","otherMenuApps","otherMenus","admin_menus","flatten","menu","psetsMenu","permission_sets","permission_objects","isNull","permission_set_ids","pos","ops","ops_key","currentPset","tempOps","repeatIndex","repeatPo","opsetAdmin","opsetCustomer","opsetGuest","opsetMember","opsetSupplier","opsetUser","posAdmin","posCustomer","posGuest","posMember","posSupplier","posUser","prof","guest","member","supplier","customer","disabled_actions","unreadable_fields","uneditable_fields","creator_db_url","oplog_url","MONGO_URL_CREATOR","MONGO_OPLOG_URL_CREATOR","_CREATOR_DATASOURCE","_driver","MongoInternals","RemoteCollectionDriver","oplogUrl","collection_key","newCollection","SMSQueue","_deleteRecord","action_name","executeAction","item_element","callback","moreArgs","todoArgs","ObjectGrid","getFilters","word_template","SteedosFilters","formatFiltersToODataQuery","absoluteUrl","window","open","odata","prototype","slice","concat","warning","record_title","call_back","call_back_error","previousDoc","FormManager","getPreviousDoc","info","success","runHook","relatedObjectStandardNew","collection_name","current_object_name","current_record_id","defaultDoc","initialValues","relateObject","set","getRelatedInitialValues","SteedosUI","showModal","stores","ComponentRegistry","components","ObjectForm","objectApiName","title","afterInsert","reloadRecord","FlowRouter","reload","iconPath","defer","$","click","gridName","isRelated","masterRecordId","relatedFieldName","selectedRows","gridRefs","current","api","getSelectedRows","gridRef","getInitialValues","Page","Form","StandardNew","render","href","getObjectUrl","redirect","StandardEdit","beforeHook","i18nTextKey","i18nTitleKey","nameField","selectedRecords","text","getTableSelectedRows","swal","showCancelButton","confirmButtonText","cancelButtonText","afterBatchesDelete","deleteCounter","_e","appid","dxDataGridInstance","gridContainer","gridObjectNameClass","isOpenerRemove","recordUrl","tempNavRemoved","opener","route","endsWith","refreshGrid","dxTreeList","dxDataGrid","refresh","removeTempNavItem","close","go","addClass","removeClass","recordTitle"],"mappings":"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","file":"/packages/steedos_objects.js","sourcesContent":["@db = {}\nif !Creator?\n\t@Creator = {}\nCreator.Objects = {}\nCreator.Collections = {}\nCreator.Menus = []\nCreator.Apps = {}\nCreator.Dashboards = {}\nCreator.Reports = {}\nCreator.subs = {}\nCreator.steedosSchema = {}","this.db = {};\n\nif (typeof Creator === \"undefined\" || Creator === null) {\n  this.Creator = {};\n}\n\nCreator.Objects = {};\n\nCreator.Collections = {};\n\nCreator.Menus = [];\n\nCreator.Apps = {};\n\nCreator.Dashboards = {};\n\nCreator.Reports = {};\n\nCreator.subs = {};\n\nCreator.steedosSchema = {};\n","try\n\tif process.env.CREATOR_NODE_ENV == 'development'\n\t\tsteedosCore = require('@steedos/core')\n\t\tobjectql = require('@steedos/objectql')\n\t\tmoleculer = require(\"moleculer\");\n\t\tpackageLoader = require('@steedos/service-meteor-package-loader');\n\t\tAPIService = require('@steedos/service-api');\n\t\tMetadataService = require('@steedos/service-metadata-server');\n\t\tpackageService = require(\"@steedos/service-package-registry\");\n\t\tpath = require('path')\n\n\t\tconfig = objectql.getSteedosConfig();\n\t\tsettings = {\n\t\t\tbuilt_in_plugins: [\n\t\t\t\t\"@steedos/standard-space\",\n\t\t\t\t\"@steedos/standard-object-database\",\n\t\t\t\t\"@steedos/standard-process-approval\",\n\t\t\t\t\"@steedos/standard-collaboration\",\n\t\t\t\t\"@steedos/standard-ui\",\n\t\t\t\t\"@steedos/standard-permission\",\n\t\t\t\t\"@steedos/webapp-public\",\n\t\t\t\t\"@steedos/service-cachers-manager\",\n\t\t\t\t\"@steedos/unpkg\",\n\t\t\t\t\"@steedos/workflow\",\n\t\t\t\t\"@steedos/accounts\",\n\t\t\t\t\"@steedos/plugin-company\",\n\t\t\t\t\"@steedos/metadata-api\",\n\t\t\t\t\"@steedos/data-import\",\n\t\t\t\t# \"@steedos/service-fields-indexs\",\n\t\t\t\t\"@steedos/service-accounts\",\n\t\t\t\t\"@steedos/service-charts\",\n\t\t\t\t# \"@steedos/service-pages\",\n\t\t\t\t\"@steedos/service-package-registry\",\n\t\t   \t\t\"@steedos/service-package-tool\",\n\t\t\t\t# \"@steedos/standard-process\",\n\t\t\t\t\"@steedos/webapp-accounts\",\n\t\t\t\t\"@steedos/service-workflow\",\n\t\t\t\t\"@steedos/service-plugin-amis\",\n\t\t\t\t\"@steedos/service-files\",\n\t\t\t\t\"@steedos/service-sentry\",\n\t\t\t\t\"@steedos/service-identity-jwt\"\n\t\t\t],\n\t\t\tplugins: config.plugins\n\t\t}\n\t\tMeteor.startup ->\n\t\t\ttry\n\t\t\t\tbroker = new moleculer.ServiceBroker({\n\t\t\t\t\tnamespace: \"steedos\",\n\t\t\t\t\tnodeID: \"steedos-creator\",\n\t\t\t\t\tmetadata: {},\n\t\t\t\t\ttransporter: process.env.TRANSPORTER,\n\t\t\t\t\tcacher: process.env.CACHER,\n\t\t\t\t\tlogLevel: \"warn\",\n\t\t\t\t\tserializer: \"JSON\",\n\t\t\t\t\trequestTimeout: 60 * 1000,\n\t\t\t\t\tmaxCallLevel: 100,\n\n\t\t\t\t\theartbeatInterval: 10,\n\t\t\t\t\theartbeatTimeout: 30,\n\n\t\t\t\t\tcontextParamsCloning: false,\n\n\t\t\t\t\ttracking: {\n\t\t\t\t\t\tenabled: false,\n\t\t\t\t\t\tshutdownTimeout: 5000,\n\t\t\t\t\t},\n\n\t\t\t\t\tdisableBalancer: false,\n\n\t\t\t\t\tregistry: {\n\t\t\t\t\t\tstrategy: \"RoundRobin\",\n\t\t\t\t\t\tpreferLocal: true\n\t\t\t\t\t},\n\n\t\t\t\t\tbulkhead: {\n\t\t\t\t\t\tenabled: false,\n\t\t\t\t\t\tconcurrency: 10,\n\t\t\t\t\t\tmaxQueueSize: 100,\n\t\t\t\t\t},\n\t\t\t\t\tvalidator: true,\n\t\t\t\t\terrorHandler: null,\n\t\t\t\t\ttracing: {\n\t\t\t\t\t\tenabled: false,\n\t\t\t\t\t\texporter: {\n\t\t\t\t\t\t\ttype: \"Console\",\n\t\t\t\t\t\t\toptions: {\n\t\t\t\t\t\t\t\tlogger: null,\n\t\t\t\t\t\t\t\tcolors: true,\n\t\t\t\t\t\t\t\twidth: 100,\n\t\t\t\t\t\t\t\tgaugeWidth: 40\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t\tskipProcessEventRegistration: true,\n\n\t\t\t\t\tcreated: (broker)-> \n\t\t\t\t\t\t# Clear all cache entries\n\t\t\t\t\t\tbroker.logger.warn('Clear all cache entries on startup.')\n\t\t\t\t\t\tbroker.cacher.clean();\n\t\t\t\t});\n\n\t\t\t\tobjectql.broker.init(broker);\n\n\t\t\t\tobjectqlService = broker.createService(require(\"@steedos/service-objectql\"));\n\t\t\t\t\n\t\t\t\tprojectService = broker.createService({\n\t\t\t\t\tname: \"project-server\",\n\t\t\t\t\tnamespace: \"steedos\",\n\t\t\t\t\tmixins: [packageService],\n\t\t\t\t});\n\n\n\t\t\t\tmetadataService = broker.createService({\n\t\t\t\t\tname: 'metadata-server',\n\t\t\t\t\tmixins: [MetadataService],\n\t\t\t\t\tsettings: {\n\t\t\t\t\t} \n\t\t\t\t});\n\n\t\t\t\tuiService = broker.createService(require(\"@steedos/service-ui\"));\n\n\t\t\t\tapiService = broker.createService({\n\t\t\t\t\tname: \"api\",\n\t\t\t\t\tmixins: [APIService],\n\t\t\t\t\tsettings: {\n\t\t\t\t\t\tport: null\n\t\t\t\t\t} \n\t\t\t\t});\n\n\t\t\t\tpageService = broker.createService({\n\t\t\t\t\tname: \"@steedos/service-pages\",\n\t\t\t\t\tmixins: [require('@steedos/service-pages')],\n\t\t\t\t\tsettings: {\n\t\t\t\t\t\tport: null\n\t\t\t\t\t} \n\t\t\t\t});\n\n\t\t\t\tsteedosService = broker.createService({\n\t\t\t\t\tname: \"steedos-server\",\n\t\t\t\t\tmixins: [],\n\t\t\t\t\tsettings: {\n\t\t\t\t\t\tport: null\n\t\t\t\t\t},\n\t\t\t\t\tstarted: ()->\n\t\t\t\t\t\tsetTimeout ->\n\t\t\t\t\t\t\tbroker.emit 'steedos-server.started'\n\t\t\t\t\t\t\treturn\n\t\t\t\t\t\t, 1000\n\t\t\t\t});\n\n\t\t\t\tobjectql.getSteedosSchema(broker);\n\t\t\t\tstandardObjectsDir = objectql.StandardObjectsPath;\n\t\t\t\tstandardObjectsPackageLoaderService = broker.createService({\n\t\t\t\t\tname: 'standard-objects',\n\t\t\t\t\tmixins: [packageLoader],\n\t\t\t\t\tsettings: { packageInfo: {\n\t\t\t\t\t\tpath: standardObjectsDir,\n\t\t\t\t\t} }\n\t\t\t\t});\n\n\t\t\t\tMeteor.wrapAsync((cb)->\n\t\t\t\t\tbroker.start().then(()->\n\t\t\t\t\t\tif !broker.started \n\t\t\t\t\t\t\tbroker._restartService(objectqlService);\n\t\t\t\t\t\t\tbroker._restartService(standardObjectsPackageLoaderService);\n\t\t\t\t\t\t\tbroker._restartService(uiService);\n\n\t\t\t\t\t\texpress = require('express');\n\t\t\t\t\t\tconnectHandlersExpress = express();\n\t\t\t\t\t\tconnectHandlersExpress.use(require('@steedos/router').staticRouter());\n\t\t\t\t\t\tbroker.waitForServices('~packages-@steedos/service-ui').then ()->\n\t\t\t\t\t\t\tconsole.log('waitForServices ~packages-@steedos/service-ui')\n\t\t\t\t\t\t\tconnectHandlersExpress.use(SteedosApi.express())\n\t\t\t\t\t\t\tWebApp.connectHandlers.use(connectHandlersExpress)\n\t\t\t\t\t\t\n\t\t\t\t\t\t# steedosCore.init(settings).then ()->\n\t\t\t\t\t\t# \tcb();\n\n\t\t\t\t\t\tbroker.waitForServices(standardObjectsPackageLoaderService.name).then (resolve, reject) ->\n\t\t\t\t\t\t\tsteedosCore.init(settings).then ()->\n\t\t\t\t\t\t\t\tcb(reject, resolve)\n\t\t\t\t\t)\n\t\t\t\t)()\n\t\t\tcatch ex\n\t\t\t\tconsole.error(\"error:\",ex)\ncatch e\n\tconsole.error(\"error:\",e)","var APIService, MetadataService, config, e, moleculer, objectql, packageLoader, packageService, path, settings, steedosCore;\n\ntry {\n  if (process.env.CREATOR_NODE_ENV === 'development') {\n    steedosCore = require('@steedos/core');\n    objectql = require('@steedos/objectql');\n    moleculer = require(\"moleculer\");\n    packageLoader = require('@steedos/service-meteor-package-loader');\n    APIService = require('@steedos/service-api');\n    MetadataService = require('@steedos/service-metadata-server');\n    packageService = require(\"@steedos/service-package-registry\");\n    path = require('path');\n    config = objectql.getSteedosConfig();\n    settings = {\n      built_in_plugins: [\"@steedos/standard-space\", \"@steedos/standard-object-database\", \"@steedos/standard-process-approval\", \"@steedos/standard-collaboration\", \"@steedos/standard-ui\", \"@steedos/standard-permission\", \"@steedos/webapp-public\", \"@steedos/service-cachers-manager\", \"@steedos/unpkg\", \"@steedos/workflow\", \"@steedos/accounts\", \"@steedos/plugin-company\", \"@steedos/metadata-api\", \"@steedos/data-import\", \"@steedos/service-accounts\", \"@steedos/service-charts\", \"@steedos/service-package-registry\", \"@steedos/service-package-tool\", \"@steedos/webapp-accounts\", \"@steedos/service-workflow\", \"@steedos/service-plugin-amis\", \"@steedos/service-files\", \"@steedos/service-sentry\", \"@steedos/service-identity-jwt\"],\n      plugins: config.plugins\n    };\n    Meteor.startup(function() {\n      var apiService, broker, ex, metadataService, objectqlService, pageService, projectService, standardObjectsDir, standardObjectsPackageLoaderService, steedosService, uiService;\n      try {\n        broker = new moleculer.ServiceBroker({\n          namespace: \"steedos\",\n          nodeID: \"steedos-creator\",\n          metadata: {},\n          transporter: process.env.TRANSPORTER,\n          cacher: process.env.CACHER,\n          logLevel: \"warn\",\n          serializer: \"JSON\",\n          requestTimeout: 60 * 1000,\n          maxCallLevel: 100,\n          heartbeatInterval: 10,\n          heartbeatTimeout: 30,\n          contextParamsCloning: false,\n          tracking: {\n            enabled: false,\n            shutdownTimeout: 5000\n          },\n          disableBalancer: false,\n          registry: {\n            strategy: \"RoundRobin\",\n            preferLocal: true\n          },\n          bulkhead: {\n            enabled: false,\n            concurrency: 10,\n            maxQueueSize: 100\n          },\n          validator: true,\n          errorHandler: null,\n          tracing: {\n            enabled: false,\n            exporter: {\n              type: \"Console\",\n              options: {\n                logger: null,\n                colors: true,\n                width: 100,\n                gaugeWidth: 40\n              }\n            }\n          },\n          skipProcessEventRegistration: true,\n          created: function(broker) {\n            broker.logger.warn('Clear all cache entries on startup.');\n            return broker.cacher.clean();\n          }\n        });\n        objectql.broker.init(broker);\n        objectqlService = broker.createService(require(\"@steedos/service-objectql\"));\n        projectService = broker.createService({\n          name: \"project-server\",\n          namespace: \"steedos\",\n          mixins: [packageService]\n        });\n        metadataService = broker.createService({\n          name: 'metadata-server',\n          mixins: [MetadataService],\n          settings: {}\n        });\n        uiService = broker.createService(require(\"@steedos/service-ui\"));\n        apiService = broker.createService({\n          name: \"api\",\n          mixins: [APIService],\n          settings: {\n            port: null\n          }\n        });\n        pageService = broker.createService({\n          name: \"@steedos/service-pages\",\n          mixins: [require('@steedos/service-pages')],\n          settings: {\n            port: null\n          }\n        });\n        steedosService = broker.createService({\n          name: \"steedos-server\",\n          mixins: [],\n          settings: {\n            port: null\n          },\n          started: function() {\n            return setTimeout(function() {\n              broker.emit('steedos-server.started');\n            }, 1000);\n          }\n        });\n        objectql.getSteedosSchema(broker);\n        standardObjectsDir = objectql.StandardObjectsPath;\n        standardObjectsPackageLoaderService = broker.createService({\n          name: 'standard-objects',\n          mixins: [packageLoader],\n          settings: {\n            packageInfo: {\n              path: standardObjectsDir\n            }\n          }\n        });\n        return Meteor.wrapAsync(function(cb) {\n          return broker.start().then(function() {\n            var connectHandlersExpress, express;\n            if (!broker.started) {\n              broker._restartService(objectqlService);\n              broker._restartService(standardObjectsPackageLoaderService);\n              broker._restartService(uiService);\n            }\n            express = require('express');\n            connectHandlersExpress = express();\n            connectHandlersExpress.use(require('@steedos/router').staticRouter());\n            broker.waitForServices('~packages-@steedos/service-ui').then(function() {\n              console.log('waitForServices ~packages-@steedos/service-ui');\n              connectHandlersExpress.use(SteedosApi.express());\n              return WebApp.connectHandlers.use(connectHandlersExpress);\n            });\n            return broker.waitForServices(standardObjectsPackageLoaderService.name).then(function(resolve, reject) {\n              return steedosCore.init(settings).then(function() {\n                return cb(reject, resolve);\n              });\n            });\n          });\n        })();\n      } catch (error) {\n        ex = error;\n        return console.error(\"error:\", ex);\n      }\n    });\n  }\n} catch (error) {\n  e = error;\n  console.error(\"error:\", e);\n}\n","Creator.deps = {\n\tapp: new Tracker.Dependency\n\tobject: new Tracker.Dependency\n};\n\nCreator._TEMPLATE = {\n\tApps: {},\n\tObjects: {}\n}\n\nMeteor.startup ->\n\tSimpleSchema.extendOptions({filtersFunction: Match.Optional(Match.OneOf(Function, String))})\n\tSimpleSchema.extendOptions({optionsFunction: Match.Optional(Match.OneOf(Function, String))})\n\tSimpleSchema.extendOptions({createFunction: Match.Optional(Match.OneOf(Function, String))})\n\n# Creator.fiberLoadObjects 供steedos-cli项目使用\nif Meteor.isServer\n\tFiber = require('fibers')\n\tCreator.fiberLoadObjects = (obj, object_name)->\n\t\tFiber(()->\n\t\t\tCreator.loadObjects(obj, object_name)\n\t\t).run()\n\nCreator.loadObjects = (obj, object_name)->\n\tif !object_name\n\t\tobject_name = obj.name\n\n\tif !obj.list_views\n\t\tobj.list_views = {}\n\n\tif obj.space\n\t\tobject_name = Creator.getCollectionName(obj)\n\tif object_name == 'cfs_files_filerecord'\n\t\tobject_name = 'cfs.files.filerecord'\n\t\tobj = _.clone(obj)\n\t\tobj.name = object_name\n\t\tCreator.Objects[object_name] = obj\n\n\tCreator.convertObject(obj)\n\tnew Creator.Object(obj);\n\n\tCreator.initTriggers(object_name)\n\tCreator.initListViews(object_name)\n\treturn obj\n\nCreator.getObjectName = (object) ->\n\tif object.space\n\t\treturn \"c_#{object.space}_#{object.name}\"\n\treturn object.name\n\nCreator.getObject = (object_name, space_id)->\n\tif _.isArray(object_name)\n\t\treturn ;\n\tif Meteor.isClient\n\t\tCreator.deps?.object?.depend()\n\tif !object_name and Meteor.isClient\n\t\tobject_name = Session.get(\"object_name\")\n\n#\tif !space_id && object_name\n#\t\tif Meteor.isClient && !object_name.startsWith('c_')\n#\t\t\tspace_id = Session.get(\"spaceId\")\n\n\tif object_name\n#\t\tif space_id\n#\t\t\tobj = Creator.objectsByName[\"c_#{space_id}_#{object_name}\"]\n#\t\t\tif obj\n#\t\t\t\treturn obj\n#\n#\t\tobj = _.find Creator.objectsByName, (o)->\n#\t\t\t\treturn o._collection_name == object_name\n#\t\tif obj\n#\t\t\treturn obj\n\n\t\treturn Creator.objectsByName[object_name]\n\nCreator.getObjectById = (object_id)->\n\treturn _.findWhere(Creator.objectsByName, {_id: object_id})\n\nCreator.removeObject = (object_name)->\n\tconsole.log(\"removeObject\", object_name)\n\tdelete Creator.Objects[object_name]\n\tdelete Creator.objectsByName[object_name]\n\nCreator.getCollection = (object_name, spaceId)->\n\tif !object_name\n\t\tobject_name = Session.get(\"object_name\")\n\tif object_name\n\t\tif Meteor.isClient\n\t\t\treturn db[object_name]\n\t\telse\n\t\t\treturn Creator.Collections[Creator.getObject(object_name, spaceId)?._collection_name || object_name]\n\nCreator.removeCollection = (object_name)->\n\tdelete Creator.Collections[object_name]\n\nCreator.isSpaceAdmin = (spaceId, userId)->\n\tif Meteor.isClient\n\t\tif !spaceId\n\t\t\tspaceId = Session.get(\"spaceId\")\n\t\tif !userId\n\t\t\tuserId = Meteor.userId()\n\n\tspace = Creator.getObject(\"spaces\")?.db?.findOne(spaceId,{fields:{admins:1}})\n\tif space?.admins\n\t\treturn space.admins.indexOf(userId) >= 0\n\n\nCreator.evaluateFormula = (formular, context, options)->\n\n\tif !_.isString(formular)\n\t\treturn formular\n\n\tif Creator.Formular.checkFormula(formular)\n\t\treturn Creator.Formular.run(formular, context, options)\n\n\treturn formular\n\nCreator.evaluateFilters = (filters, context)->\n\tselector = {}\n\t_.each filters, (filter)->\n\t\tif filter?.length == 3\n\t\t\tname = filter[0]\n\t\t\taction = filter[1]\n\t\t\tvalue = Creator.evaluateFormula(filter[2], context)\n\t\t\tselector[name] = {}\n\t\t\tselector[name][action] = value\n\t# console.log(\"evaluateFilters-->selector\", selector)\n\treturn selector\n\nCreator.isCommonSpace = (spaceId) ->\n\treturn spaceId == 'common'\n\n###\n\tdocs：待排序的文档数组\n\tids：_id集合\n\tid_key: 默认为_id\n\treturn 按照ids的顺序返回新的文档集合\n###\nCreator.getOrderlySetByIds = (docs, ids, id_key, hit_first)->\n\n\tif !id_key\n\t\tid_key = \"_id\"\n\n\tif hit_first\n\n\t\t#由于不能使用_.findIndex函数，因此此处先将对象数组转为普通数组类型，在获取其index\n\t\tvalues = docs.getProperty(id_key)\n\n\t\treturn\t_.sortBy docs, (doc)->\n\t\t\t\t\t_index = ids.indexOf(doc[id_key])\n\t\t\t\t\tif _index > -1\n\t\t\t\t\t\treturn _index\n\t\t\t\t\telse\n\t\t\t\t\t\treturn ids.length + _.indexOf(values, doc[id_key])\n\telse\n\t\treturn\t_.sortBy docs, (doc)->\n\t\t\tv = ids.indexOf(doc[id_key]);\n\t\t\tif v < 0\n\t\t\t\treturn 99999\n\t\t\telse \n\t\t\t\treturn v\n\n###\n\t按用户所属本地化语言进行排序，支持中文、数值、日期等字段排序\n\t对于Object类型，如果提供作用域中key属性，则取值为value[key]进行排序比较，反之整个Object.toString()后排序比较\n###\nCreator.sortingMethod = (value1, value2) ->\n\tif this.key\n\t\tvalue1 = value1[this.key]\n\t\tvalue2 = value2[this.key]\n\tif value1 instanceof Date\n\t\tvalue1 = value1.getTime()\n\tif value2 instanceof Date\n\t\tvalue2 = value2.getTime()\n\tif typeof value1 is \"number\" and typeof value2 is \"number\"\n\t\treturn value1 - value2\n\t# Handling null values\n\tisValue1Empty = value1 == null or value1 == undefined\n\tisValue2Empty = value2 == null or value2 == undefined\n\tif isValue1Empty and !isValue2Empty\n\t\treturn -1\n\tif isValue1Empty and isValue2Empty\n\t\treturn 0\n\tif !isValue1Empty and isValue2Empty\n\t\treturn 1\n\tlocale = Steedos.locale()\n\treturn value1.toString().localeCompare value2.toString(), locale\n\n\n# 该函数只在初始化Object时，把相关对象的计算结果保存到Object的related_objects属性中，后续可以直接从related_objects属性中取得计算结果而不用再次调用该函数来计算\nCreator.getObjectRelateds = (object_name)->\n\tif Meteor.isClient\n\t\tif !object_name\n\t\t\tobject_name = Session.get(\"object_name\")\n\n\trelated_objects = []\n\t# _object = Creator.getObject(object_name)\n\t# 因Creator.getObject函数内部要调用该函数，所以这里不可以调用Creator.getObject取对象，只能调用Creator.Objects来取对象\n\t_object = Creator.Objects[object_name]\n\tif !_object\n\t\treturn related_objects\n\t\n\trelatedList = _object.relatedList\n\tif Meteor.isClient && !_.isEmpty relatedList\n\t\trelatedListMap = {}\n\t\t_.each relatedList, (objName)->\n\t\t\tif _.isObject objName\n\t\t\t\trelatedListMap[objName.objectName] = {}\n\t\t\telse\n\t\t\t\trelatedListMap[objName] = {}\n\t\t_.each Creator.Objects, (related_object, related_object_name)->\n\t\t\t_.each related_object.fields, (related_field, related_field_name)->\n\t\t\t\tif (related_field.type == \"master_detail\" || related_field.type == \"lookup\") and related_field.reference_to and related_field.reference_to == object_name and relatedListMap[related_object_name]\n\t\t\t\t\t# 当related_object.fields中有两个或以上的字段指向object_name表示的对象时，优先取第一个作为外键关系字段，但是related_field为主子表时强行覆盖之前的relatedListMap[related_object_name]值\n\t\t\t\t\tif _.isEmpty relatedListMap[related_object_name] || related_field.type == \"master_detail\"\n\t\t\t\t\t\trelatedListMap[related_object_name] = { object_name: related_object_name, foreign_key: related_field_name, write_requires_master_read: related_field.write_requires_master_read }\n\t\tif relatedListMap['cms_files']\n\t\t\trelatedListMap['cms_files'] = { object_name: \"cms_files\", foreign_key: \"parent\" }\n\t\tif relatedListMap['instances']\n\t\t\trelatedListMap['instances'] = { object_name: \"instances\", foreign_key: \"record_ids\" }\n\t\t_.each ['tasks', 'notes', 'events', 'approvals'], (enableObjName)->\n\t\t\tif relatedListMap[enableObjName]\n\t\t\t\trelatedListMap[enableObjName] = { object_name: enableObjName, foreign_key: \"related_to\" }\n\t\tif relatedListMap['audit_records']\n\t\t\t#record 详细下的audit_records仅modifyAllRecords权限可见\n\t\t\tpermissions = Creator.getPermissions(object_name)\n\t\t\tif _object.enable_audit && permissions?.modifyAllRecords\n\t\t\t\trelatedListMap['audit_records'] = { object_name:\"audit_records\", foreign_key: \"related_to\" }\n\t\trelated_objects = _.values relatedListMap\n\t\treturn related_objects\n\n\tif _object.enable_files\n\t\trelated_objects.push {object_name:\"cms_files\", foreign_key: \"parent\"}\n\n\t_.each Creator.Objects, (related_object, related_object_name)->\n\t\tif related_object_name == \"cfs.files.filerecord\"\n\t\t\t# cfs.files.filerecord对象在第二次点击的时候related_object返回的是app-builder中的\"metadata.parent\"字段被删除了，记到metadata字段的sub_fields中了，所以要单独处理。\n\t\t\tsfsFilesObject = Creator.getObject(\"cfs.files.filerecord\")\n\t\t\tsfsFilesObject && related_object = sfsFilesObject\n\t\t_.each related_object.fields, (related_field, related_field_name)->\n\t\t\tif (related_field.type == \"master_detail\" || (related_field.type == \"lookup\" && related_field.relatedList)) and related_field.reference_to and related_field.reference_to == object_name\n\t\t\t\tif related_object_name == \"object_fields\"\n\t\t\t\t\t#TODO 待相关列表支持排序后，删除此判断\n\t\t\t\t\trelated_objects.splice(0, 0, {object_name:related_object_name, foreign_key: related_field_name})\n\t\t\t\telse\n\t\t\t\t\trelated_objects.push {object_name:related_object_name, foreign_key: related_field_name, write_requires_master_read: related_field.write_requires_master_read}\n\n\tif _object.enable_tasks\n\t\trelated_objects.push {object_name:\"tasks\", foreign_key: \"related_to\"}\n\tif _object.enable_notes\n\t\trelated_objects.push {object_name:\"notes\", foreign_key: \"related_to\"}\n\tif _object.enable_events\n\t\trelated_objects.push {object_name:\"events\", foreign_key: \"related_to\"}\n\tif _object.enable_instances\n\t\trelated_objects.push {object_name:\"instances\", foreign_key: \"record_ids\"}\n\tif _object.enable_approvals\n\t\trelated_objects.push {object_name:\"approvals\", foreign_key: \"related_to\"}\n\tif _object.enable_process\n\t\trelated_objects.push {object_name:\"process_instance_history\", foreign_key: \"target_object\"}\n\t#record 详细下的audit_records仅modifyAllRecords权限可见\n\tif Meteor.isClient\n\t\tpermissions = Creator.getPermissions(object_name)\n\t\tif _object.enable_audit && permissions?.modifyAllRecords\n\t\t\trelated_objects.push {object_name:\"audit_records\", foreign_key: \"related_to\"}\n\n\treturn related_objects\n\nCreator.getUserContext = (userId, spaceId, isUnSafeMode)->\n\tif Meteor.isClient\n\t\treturn Creator.USER_CONTEXT\n\telse\n\t\tif !(userId and spaceId)\n\t\t\tthrow new Meteor.Error 500, \"the params userId and spaceId is required for the function Creator.getUserContext\"\n\t\t\treturn null\n\t\tsuFields = {name: 1, mobile: 1, position: 1, email: 1, company: 1, organization: 1, space: 1, company_id: 1, company_ids: 1}\n\t\t# check if user in the space\n\t\tsu = Creator.Collections[\"space_users\"].findOne({space: spaceId, user: userId}, {fields: suFields})\n\t\tif !su\n\t\t\tspaceId = null\n\n\t\t# if spaceId not exists, get the first one.\n\t\tif !spaceId\n\t\t\tif isUnSafeMode\n\t\t\t\tsu = Creator.Collections[\"space_users\"].findOne({user: userId}, {fields: suFields})\n\t\t\t\tif !su\n\t\t\t\t\treturn null\n\t\t\t\tspaceId = su.space\n\t\t\telse\n\t\t\t\treturn null\n\n\t\tUSER_CONTEXT = {}\n\t\tUSER_CONTEXT.userId = userId\n\t\tUSER_CONTEXT.spaceId = spaceId\n\t\tUSER_CONTEXT.user = {\n\t\t\t_id: userId\n\t\t\tname: su.name,\n\t\t\tmobile: su.mobile,\n\t\t\tposition: su.position,\n\t\t\temail: su.email\n\t\t\tcompany: su.company\n\t\t\tcompany_id: su.company_id\n\t\t\tcompany_ids: su.company_ids\n\t\t}\n\t\tspace_user_org = Creator.getCollection(\"organizations\")?.findOne(su.organization)\n\t\tif space_user_org\n\t\t\tUSER_CONTEXT.user.organization = {\n\t\t\t\t_id: space_user_org._id,\n\t\t\t\tname: space_user_org.name,\n\t\t\t\tfullname: space_user_org.fullname\n\t\t\t}\n\t\treturn USER_CONTEXT\n\nCreator.getRelativeUrl = (url)->\n\n\tif _.isFunction(Steedos.isCordova) && Steedos.isCordova() && (url?.startsWith(\"/assets\") || url?.startsWith(\"assets\") || url?.startsWith(\"/packages\"))\n\t\tif !/^\\//.test(url)\n\t\t\turl = \"/\" + url\n\t\treturn url\n\n\tif url\n\t\t# url开头没有\"/\"，需要添加\"/\"\n\t\tif !/^\\//.test(url)\n\t\t\turl = \"/\" + url\n\t\treturn __meteor_runtime_config__.ROOT_URL_PATH_PREFIX + url\n\telse\n\t\treturn __meteor_runtime_config__.ROOT_URL_PATH_PREFIX\n\nCreator.getUserCompanyId = (userId, spaceId)->\n\tuserId = userId || Meteor.userId()\n\tif Meteor.isClient\n\t\tspaceId = spaceId || Session.get('spaceId')\n\telse\n\t\tif !spaceId\n\t\t\tthrow new Meteor.Error(400, 'miss spaceId')\n\tsu = Creator.getCollection('space_users').findOne({space: spaceId, user: userId}, {fields: {company_id:1}})\n\treturn su.company_id\n\nCreator.getUserCompanyIds = (userId, spaceId)->\n\tuserId = userId || Meteor.userId()\n\tif Meteor.isClient\n\t\tspaceId = spaceId || Session.get('spaceId')\n\telse\n\t\tif !spaceId\n\t\t\tthrow new Meteor.Error(400, 'miss spaceId')\n\tsu = Creator.getCollection('space_users').findOne({space: spaceId, user: userId}, {fields: {company_ids:1}})\n\treturn su?.company_ids\n\nCreator.processPermissions = (po)->\n\tif po.allowCreate\n\t\tpo.allowRead = true\n\tif po.allowEdit\n\t\tpo.allowRead = true\n\tif po.allowDelete\n\t\tpo.allowEdit = true\n\t\tpo.allowRead = true\n\tif po.viewAllRecords\n\t\tpo.allowRead = true\n\tif po.modifyAllRecords\n\t\tpo.allowRead = true\n\t\tpo.allowEdit = true\n\t\tpo.allowDelete = true\n\t\tpo.viewAllRecords = true\n\tif po.viewCompanyRecords\n\t\tpo.allowRead = true\n\tif po.modifyCompanyRecords\n\t\tpo.allowRead = true\n\t\tpo.allowEdit = true\n\t\tpo.allowDelete = true\n\t\tpo.viewCompanyRecords = true\n\t\t\n\t# 如果附件相关权限配置为空，则兼容之前没有附件权限配置时的规则\n\tif po.allowRead\n\t\ttypeof po.allowReadFiles != \"boolean\" && po.allowReadFiles = true\n\t\ttypeof po.viewAllFiles != \"boolean\" && po.viewAllFiles = true\n\tif po.allowEdit\n\t\ttypeof po.allowCreateFiles != \"boolean\" && po.allowCreateFiles = true\n\t\ttypeof po.allowEditFiles != \"boolean\" && po.allowEditFiles = true\n\t\ttypeof po.allowDeleteFiles != \"boolean\" && po.allowDeleteFiles = true\n\tif po.modifyAllRecords\n\t\ttypeof po.modifyAllFiles != \"boolean\" && po.modifyAllFiles = true\n\n\tif po.allowCreateFiles\n\t\tpo.allowReadFiles = true\n\tif po.allowEditFiles\n\t\tpo.allowReadFiles = true\n\tif po.allowDeleteFiles\n\t\tpo.allowEditFiles = true\n\t\tpo.allowReadFiles = true\n\tif po.viewAllFiles\n\t\tpo.allowReadFiles = true\n\tif po.modifyAllFiles\n\t\tpo.allowReadFiles = true\n\t\tpo.allowEditFiles = true\n\t\tpo.allowDeleteFiles = true\n\t\tpo.viewAllFiles = true\n\n\treturn po\n\nCreator.getTemplateSpaceId = ()->\n\treturn Meteor.settings.public?.templateSpaceId\n\nCreator.getCloudAdminSpaceId = ()->\n\treturn Meteor.settings.public?.cloudAdminSpaceId\n\nCreator.isTemplateSpace = (spaceId)->\n\tif spaceId && Meteor.settings.public?.templateSpaceId == spaceId\n\t\treturn true\n\treturn false\n\nCreator.isCloudAdminSpace = (spaceId)->\n\tif spaceId && Meteor.settings.public?.cloudAdminSpaceId == spaceId\n\t\treturn true\n\treturn false\n\nif Meteor.isServer\n\tCreator.steedosStorageDir = process.env.STEEDOS_STORAGE_DIR\n\t","var Fiber;\n\nCreator.deps = {\n  app: new Tracker.Dependency,\n  object: new Tracker.Dependency\n};\n\nCreator._TEMPLATE = {\n  Apps: {},\n  Objects: {}\n};\n\nMeteor.startup(function() {\n  SimpleSchema.extendOptions({\n    filtersFunction: Match.Optional(Match.OneOf(Function, String))\n  });\n  SimpleSchema.extendOptions({\n    optionsFunction: Match.Optional(Match.OneOf(Function, String))\n  });\n  return SimpleSchema.extendOptions({\n    createFunction: Match.Optional(Match.OneOf(Function, String))\n  });\n});\n\nif (Meteor.isServer) {\n  Fiber = require('fibers');\n  Creator.fiberLoadObjects = function(obj, object_name) {\n    return Fiber(function() {\n      return Creator.loadObjects(obj, object_name);\n    }).run();\n  };\n}\n\nCreator.loadObjects = function(obj, object_name) {\n  if (!object_name) {\n    object_name = obj.name;\n  }\n  if (!obj.list_views) {\n    obj.list_views = {};\n  }\n  if (obj.space) {\n    object_name = Creator.getCollectionName(obj);\n  }\n  if (object_name === 'cfs_files_filerecord') {\n    object_name = 'cfs.files.filerecord';\n    obj = _.clone(obj);\n    obj.name = object_name;\n    Creator.Objects[object_name] = obj;\n  }\n  Creator.convertObject(obj);\n  new Creator.Object(obj);\n  Creator.initTriggers(object_name);\n  Creator.initListViews(object_name);\n  return obj;\n};\n\nCreator.getObjectName = function(object) {\n  if (object.space) {\n    return \"c_\" + object.space + \"_\" + object.name;\n  }\n  return object.name;\n};\n\nCreator.getObject = function(object_name, space_id) {\n  var ref, ref1;\n  if (_.isArray(object_name)) {\n    return;\n  }\n  if (Meteor.isClient) {\n    if ((ref = Creator.deps) != null) {\n      if ((ref1 = ref.object) != null) {\n        ref1.depend();\n      }\n    }\n  }\n  if (!object_name && Meteor.isClient) {\n    object_name = Session.get(\"object_name\");\n  }\n  if (object_name) {\n    return Creator.objectsByName[object_name];\n  }\n};\n\nCreator.getObjectById = function(object_id) {\n  return _.findWhere(Creator.objectsByName, {\n    _id: object_id\n  });\n};\n\nCreator.removeObject = function(object_name) {\n  console.log(\"removeObject\", object_name);\n  delete Creator.Objects[object_name];\n  return delete Creator.objectsByName[object_name];\n};\n\nCreator.getCollection = function(object_name, spaceId) {\n  var ref;\n  if (!object_name) {\n    object_name = Session.get(\"object_name\");\n  }\n  if (object_name) {\n    if (Meteor.isClient) {\n      return db[object_name];\n    } else {\n      return Creator.Collections[((ref = Creator.getObject(object_name, spaceId)) != null ? ref._collection_name : void 0) || object_name];\n    }\n  }\n};\n\nCreator.removeCollection = function(object_name) {\n  return delete Creator.Collections[object_name];\n};\n\nCreator.isSpaceAdmin = function(spaceId, userId) {\n  var ref, ref1, space;\n  if (Meteor.isClient) {\n    if (!spaceId) {\n      spaceId = Session.get(\"spaceId\");\n    }\n    if (!userId) {\n      userId = Meteor.userId();\n    }\n  }\n  space = (ref = Creator.getObject(\"spaces\")) != null ? (ref1 = ref.db) != null ? ref1.findOne(spaceId, {\n    fields: {\n      admins: 1\n    }\n  }) : void 0 : void 0;\n  if (space != null ? space.admins : void 0) {\n    return space.admins.indexOf(userId) >= 0;\n  }\n};\n\nCreator.evaluateFormula = function(formular, context, options) {\n  if (!_.isString(formular)) {\n    return formular;\n  }\n  if (Creator.Formular.checkFormula(formular)) {\n    return Creator.Formular.run(formular, context, options);\n  }\n  return formular;\n};\n\nCreator.evaluateFilters = function(filters, context) {\n  var selector;\n  selector = {};\n  _.each(filters, function(filter) {\n    var action, name, value;\n    if ((filter != null ? filter.length : void 0) === 3) {\n      name = filter[0];\n      action = filter[1];\n      value = Creator.evaluateFormula(filter[2], context);\n      selector[name] = {};\n      return selector[name][action] = value;\n    }\n  });\n  return selector;\n};\n\nCreator.isCommonSpace = function(spaceId) {\n  return spaceId === 'common';\n};\n\n\n/*\n\tdocs：待排序的文档数组\n\tids：_id集合\n\tid_key: 默认为_id\n\treturn 按照ids的顺序返回新的文档集合\n */\n\nCreator.getOrderlySetByIds = function(docs, ids, id_key, hit_first) {\n  var values;\n  if (!id_key) {\n    id_key = \"_id\";\n  }\n  if (hit_first) {\n    values = docs.getProperty(id_key);\n    return _.sortBy(docs, function(doc) {\n      var _index;\n      _index = ids.indexOf(doc[id_key]);\n      if (_index > -1) {\n        return _index;\n      } else {\n        return ids.length + _.indexOf(values, doc[id_key]);\n      }\n    });\n  } else {\n    return _.sortBy(docs, function(doc) {\n      var v;\n      v = ids.indexOf(doc[id_key]);\n      if (v < 0) {\n        return 99999;\n      } else {\n        return v;\n      }\n    });\n  }\n};\n\n\n/*\n\t按用户所属本地化语言进行排序，支持中文、数值、日期等字段排序\n\t对于Object类型，如果提供作用域中key属性，则取值为value[key]进行排序比较，反之整个Object.toString()后排序比较\n */\n\nCreator.sortingMethod = function(value1, value2) {\n  var isValue1Empty, isValue2Empty, locale;\n  if (this.key) {\n    value1 = value1[this.key];\n    value2 = value2[this.key];\n  }\n  if (value1 instanceof Date) {\n    value1 = value1.getTime();\n  }\n  if (value2 instanceof Date) {\n    value2 = value2.getTime();\n  }\n  if (typeof value1 === \"number\" && typeof value2 === \"number\") {\n    return value1 - value2;\n  }\n  isValue1Empty = value1 === null || value1 === void 0;\n  isValue2Empty = value2 === null || value2 === void 0;\n  if (isValue1Empty && !isValue2Empty) {\n    return -1;\n  }\n  if (isValue1Empty && isValue2Empty) {\n    return 0;\n  }\n  if (!isValue1Empty && isValue2Empty) {\n    return 1;\n  }\n  locale = Steedos.locale();\n  return value1.toString().localeCompare(value2.toString(), locale);\n};\n\nCreator.getObjectRelateds = function(object_name) {\n  var _object, permissions, relatedList, relatedListMap, related_objects;\n  if (Meteor.isClient) {\n    if (!object_name) {\n      object_name = Session.get(\"object_name\");\n    }\n  }\n  related_objects = [];\n  _object = Creator.Objects[object_name];\n  if (!_object) {\n    return related_objects;\n  }\n  relatedList = _object.relatedList;\n  if (Meteor.isClient && !_.isEmpty(relatedList)) {\n    relatedListMap = {};\n    _.each(relatedList, function(objName) {\n      if (_.isObject(objName)) {\n        return relatedListMap[objName.objectName] = {};\n      } else {\n        return relatedListMap[objName] = {};\n      }\n    });\n    _.each(Creator.Objects, function(related_object, related_object_name) {\n      return _.each(related_object.fields, function(related_field, related_field_name) {\n        if ((related_field.type === \"master_detail\" || related_field.type === \"lookup\") && related_field.reference_to && related_field.reference_to === object_name && relatedListMap[related_object_name]) {\n          if (_.isEmpty(relatedListMap[related_object_name] || related_field.type === \"master_detail\")) {\n            return relatedListMap[related_object_name] = {\n              object_name: related_object_name,\n              foreign_key: related_field_name,\n              write_requires_master_read: related_field.write_requires_master_read\n            };\n          }\n        }\n      });\n    });\n    if (relatedListMap['cms_files']) {\n      relatedListMap['cms_files'] = {\n        object_name: \"cms_files\",\n        foreign_key: \"parent\"\n      };\n    }\n    if (relatedListMap['instances']) {\n      relatedListMap['instances'] = {\n        object_name: \"instances\",\n        foreign_key: \"record_ids\"\n      };\n    }\n    _.each(['tasks', 'notes', 'events', 'approvals'], function(enableObjName) {\n      if (relatedListMap[enableObjName]) {\n        return relatedListMap[enableObjName] = {\n          object_name: enableObjName,\n          foreign_key: \"related_to\"\n        };\n      }\n    });\n    if (relatedListMap['audit_records']) {\n      permissions = Creator.getPermissions(object_name);\n      if (_object.enable_audit && (permissions != null ? permissions.modifyAllRecords : void 0)) {\n        relatedListMap['audit_records'] = {\n          object_name: \"audit_records\",\n          foreign_key: \"related_to\"\n        };\n      }\n    }\n    related_objects = _.values(relatedListMap);\n    return related_objects;\n  }\n  if (_object.enable_files) {\n    related_objects.push({\n      object_name: \"cms_files\",\n      foreign_key: \"parent\"\n    });\n  }\n  _.each(Creator.Objects, function(related_object, related_object_name) {\n    var sfsFilesObject;\n    if (related_object_name === \"cfs.files.filerecord\") {\n      sfsFilesObject = Creator.getObject(\"cfs.files.filerecord\");\n      sfsFilesObject && (related_object = sfsFilesObject);\n    }\n    return _.each(related_object.fields, function(related_field, related_field_name) {\n      if ((related_field.type === \"master_detail\" || (related_field.type === \"lookup\" && related_field.relatedList)) && related_field.reference_to && related_field.reference_to === object_name) {\n        if (related_object_name === \"object_fields\") {\n          return related_objects.splice(0, 0, {\n            object_name: related_object_name,\n            foreign_key: related_field_name\n          });\n        } else {\n          return related_objects.push({\n            object_name: related_object_name,\n            foreign_key: related_field_name,\n            write_requires_master_read: related_field.write_requires_master_read\n          });\n        }\n      }\n    });\n  });\n  if (_object.enable_tasks) {\n    related_objects.push({\n      object_name: \"tasks\",\n      foreign_key: \"related_to\"\n    });\n  }\n  if (_object.enable_notes) {\n    related_objects.push({\n      object_name: \"notes\",\n      foreign_key: \"related_to\"\n    });\n  }\n  if (_object.enable_events) {\n    related_objects.push({\n      object_name: \"events\",\n      foreign_key: \"related_to\"\n    });\n  }\n  if (_object.enable_instances) {\n    related_objects.push({\n      object_name: \"instances\",\n      foreign_key: \"record_ids\"\n    });\n  }\n  if (_object.enable_approvals) {\n    related_objects.push({\n      object_name: \"approvals\",\n      foreign_key: \"related_to\"\n    });\n  }\n  if (_object.enable_process) {\n    related_objects.push({\n      object_name: \"process_instance_history\",\n      foreign_key: \"target_object\"\n    });\n  }\n  if (Meteor.isClient) {\n    permissions = Creator.getPermissions(object_name);\n    if (_object.enable_audit && (permissions != null ? permissions.modifyAllRecords : void 0)) {\n      related_objects.push({\n        object_name: \"audit_records\",\n        foreign_key: \"related_to\"\n      });\n    }\n  }\n  return related_objects;\n};\n\nCreator.getUserContext = function(userId, spaceId, isUnSafeMode) {\n  var USER_CONTEXT, ref, space_user_org, su, suFields;\n  if (Meteor.isClient) {\n    return Creator.USER_CONTEXT;\n  } else {\n    if (!(userId && spaceId)) {\n      throw new Meteor.Error(500, \"the params userId and spaceId is required for the function Creator.getUserContext\");\n      return null;\n    }\n    suFields = {\n      name: 1,\n      mobile: 1,\n      position: 1,\n      email: 1,\n      company: 1,\n      organization: 1,\n      space: 1,\n      company_id: 1,\n      company_ids: 1\n    };\n    su = Creator.Collections[\"space_users\"].findOne({\n      space: spaceId,\n      user: userId\n    }, {\n      fields: suFields\n    });\n    if (!su) {\n      spaceId = null;\n    }\n    if (!spaceId) {\n      if (isUnSafeMode) {\n        su = Creator.Collections[\"space_users\"].findOne({\n          user: userId\n        }, {\n          fields: suFields\n        });\n        if (!su) {\n          return null;\n        }\n        spaceId = su.space;\n      } else {\n        return null;\n      }\n    }\n    USER_CONTEXT = {};\n    USER_CONTEXT.userId = userId;\n    USER_CONTEXT.spaceId = spaceId;\n    USER_CONTEXT.user = {\n      _id: userId,\n      name: su.name,\n      mobile: su.mobile,\n      position: su.position,\n      email: su.email,\n      company: su.company,\n      company_id: su.company_id,\n      company_ids: su.company_ids\n    };\n    space_user_org = (ref = Creator.getCollection(\"organizations\")) != null ? ref.findOne(su.organization) : void 0;\n    if (space_user_org) {\n      USER_CONTEXT.user.organization = {\n        _id: space_user_org._id,\n        name: space_user_org.name,\n        fullname: space_user_org.fullname\n      };\n    }\n    return USER_CONTEXT;\n  }\n};\n\nCreator.getRelativeUrl = function(url) {\n  if (_.isFunction(Steedos.isCordova) && Steedos.isCordova() && ((url != null ? url.startsWith(\"/assets\") : void 0) || (url != null ? url.startsWith(\"assets\") : void 0) || (url != null ? url.startsWith(\"/packages\") : void 0))) {\n    if (!/^\\//.test(url)) {\n      url = \"/\" + url;\n    }\n    return url;\n  }\n  if (url) {\n    if (!/^\\//.test(url)) {\n      url = \"/\" + url;\n    }\n    return __meteor_runtime_config__.ROOT_URL_PATH_PREFIX + url;\n  } else {\n    return __meteor_runtime_config__.ROOT_URL_PATH_PREFIX;\n  }\n};\n\nCreator.getUserCompanyId = function(userId, spaceId) {\n  var su;\n  userId = userId || Meteor.userId();\n  if (Meteor.isClient) {\n    spaceId = spaceId || Session.get('spaceId');\n  } else {\n    if (!spaceId) {\n      throw new Meteor.Error(400, 'miss spaceId');\n    }\n  }\n  su = Creator.getCollection('space_users').findOne({\n    space: spaceId,\n    user: userId\n  }, {\n    fields: {\n      company_id: 1\n    }\n  });\n  return su.company_id;\n};\n\nCreator.getUserCompanyIds = function(userId, spaceId) {\n  var su;\n  userId = userId || Meteor.userId();\n  if (Meteor.isClient) {\n    spaceId = spaceId || Session.get('spaceId');\n  } else {\n    if (!spaceId) {\n      throw new Meteor.Error(400, 'miss spaceId');\n    }\n  }\n  su = Creator.getCollection('space_users').findOne({\n    space: spaceId,\n    user: userId\n  }, {\n    fields: {\n      company_ids: 1\n    }\n  });\n  return su != null ? su.company_ids : void 0;\n};\n\nCreator.processPermissions = function(po) {\n  if (po.allowCreate) {\n    po.allowRead = true;\n  }\n  if (po.allowEdit) {\n    po.allowRead = true;\n  }\n  if (po.allowDelete) {\n    po.allowEdit = true;\n    po.allowRead = true;\n  }\n  if (po.viewAllRecords) {\n    po.allowRead = true;\n  }\n  if (po.modifyAllRecords) {\n    po.allowRead = true;\n    po.allowEdit = true;\n    po.allowDelete = true;\n    po.viewAllRecords = true;\n  }\n  if (po.viewCompanyRecords) {\n    po.allowRead = true;\n  }\n  if (po.modifyCompanyRecords) {\n    po.allowRead = true;\n    po.allowEdit = true;\n    po.allowDelete = true;\n    po.viewCompanyRecords = true;\n  }\n  if (po.allowRead) {\n    typeof po.allowReadFiles !== \"boolean\" && (po.allowReadFiles = true);\n    typeof po.viewAllFiles !== \"boolean\" && (po.viewAllFiles = true);\n  }\n  if (po.allowEdit) {\n    typeof po.allowCreateFiles !== \"boolean\" && (po.allowCreateFiles = true);\n    typeof po.allowEditFiles !== \"boolean\" && (po.allowEditFiles = true);\n    typeof po.allowDeleteFiles !== \"boolean\" && (po.allowDeleteFiles = true);\n  }\n  if (po.modifyAllRecords) {\n    typeof po.modifyAllFiles !== \"boolean\" && (po.modifyAllFiles = true);\n  }\n  if (po.allowCreateFiles) {\n    po.allowReadFiles = true;\n  }\n  if (po.allowEditFiles) {\n    po.allowReadFiles = true;\n  }\n  if (po.allowDeleteFiles) {\n    po.allowEditFiles = true;\n    po.allowReadFiles = true;\n  }\n  if (po.viewAllFiles) {\n    po.allowReadFiles = true;\n  }\n  if (po.modifyAllFiles) {\n    po.allowReadFiles = true;\n    po.allowEditFiles = true;\n    po.allowDeleteFiles = true;\n    po.viewAllFiles = true;\n  }\n  return po;\n};\n\nCreator.getTemplateSpaceId = function() {\n  var ref;\n  return (ref = Meteor.settings[\"public\"]) != null ? ref.templateSpaceId : void 0;\n};\n\nCreator.getCloudAdminSpaceId = function() {\n  var ref;\n  return (ref = Meteor.settings[\"public\"]) != null ? ref.cloudAdminSpaceId : void 0;\n};\n\nCreator.isTemplateSpace = function(spaceId) {\n  var ref;\n  if (spaceId && ((ref = Meteor.settings[\"public\"]) != null ? ref.templateSpaceId : void 0) === spaceId) {\n    return true;\n  }\n  return false;\n};\n\nCreator.isCloudAdminSpace = function(spaceId) {\n  var ref;\n  if (spaceId && ((ref = Meteor.settings[\"public\"]) != null ? ref.cloudAdminSpaceId : void 0) === spaceId) {\n    return true;\n  }\n  return false;\n};\n\nif (Meteor.isServer) {\n  Creator.steedosStorageDir = process.env.STEEDOS_STORAGE_DIR;\n}\n","Meteor.methods\n\t# 用户获取lookup 、master_detail类型字段的选项值\n\t\"creator.object_options\": (options)->\n\t\tif options?.params?.reference_to\n\n\t\t\tobject = Creator.getObject(options.params.reference_to, options.params.space)\n\n\t\t\tname_field_key = object.NAME_FIELD_KEY\n\n\t\t\tquery = {}\n\t\t\tif options.params.space\n\t\t\t\tquery.space = options.params.space\n\n\t\t\t\tsort = options?.sort\n\n\t\t\t\tselected = options?.selected || []\n\n\t\t\t\toptions_limit = options?.options_limit || 10\n\n\t\t\t\tif options.searchText\n\t\t\t\t\tsearchTextQuery = {}\n\t\t\t\t\tsearchTextQuery[name_field_key] = {$regex: options.searchText}\n\n\t\t\t\tif options?.values?.length\n\t\t\t\t\tif options.searchText\n\t\t\t\t\t\tquery.$or = [{_id: {$in: options.values}}, searchTextQuery]\n\t\t\t\t\telse\n\t\t\t\t\t\tquery.$or = [{_id: {$in: options.values}}]\n\t\t\t\telse\n\t\t\t\t\tif options.searchText\n\t\t\t\t\t\t_.extend(query, searchTextQuery)\n\t\t\t\t\tquery._id = {$nin: selected}\n\n\t\t\t\tcollection = object.db\n\n\t\t\t\tif options.filterQuery\n\t\t\t\t\t_.extend query, options.filterQuery\n\n\t\t\t\tquery_options = {limit: options_limit}\n\n\t\t\t\tif sort && _.isObject(sort)\n\t\t\t\t\tquery_options.sort = sort\n\n\t\t\t\tif collection\n\t\t\t\t\ttry\n\t\t\t\t\t\trecords = collection.find(query, query_options).fetch()\n\t\t\t\t\t\tresults = []\n\t\t\t\t\t\t_.each records, (record)->\n\t\t\t\t\t\t\tresults.push\n\t\t\t\t\t\t\t\tlabel: record[name_field_key]\n\t\t\t\t\t\t\t\tvalue: record._id\n\t\t\t\t\t\treturn results\n\t\t\t\t\tcatch e\n\t\t\t\t\t\tthrow new Meteor.Error 500, e.message + \"-->\" + JSON.stringify(options)\n\t\treturn [] ","Meteor.methods({\n  \"creator.object_options\": function(options) {\n    var collection, e, name_field_key, object, options_limit, query, query_options, records, ref, ref1, results, searchTextQuery, selected, sort;\n    if (options != null ? (ref = options.params) != null ? ref.reference_to : void 0 : void 0) {\n      object = Creator.getObject(options.params.reference_to, options.params.space);\n      name_field_key = object.NAME_FIELD_KEY;\n      query = {};\n      if (options.params.space) {\n        query.space = options.params.space;\n        sort = options != null ? options.sort : void 0;\n        selected = (options != null ? options.selected : void 0) || [];\n        options_limit = (options != null ? options.options_limit : void 0) || 10;\n        if (options.searchText) {\n          searchTextQuery = {};\n          searchTextQuery[name_field_key] = {\n            $regex: options.searchText\n          };\n        }\n        if (options != null ? (ref1 = options.values) != null ? ref1.length : void 0 : void 0) {\n          if (options.searchText) {\n            query.$or = [\n              {\n                _id: {\n                  $in: options.values\n                }\n              }, searchTextQuery\n            ];\n          } else {\n            query.$or = [\n              {\n                _id: {\n                  $in: options.values\n                }\n              }\n            ];\n          }\n        } else {\n          if (options.searchText) {\n            _.extend(query, searchTextQuery);\n          }\n          query._id = {\n            $nin: selected\n          };\n        }\n        collection = object.db;\n        if (options.filterQuery) {\n          _.extend(query, options.filterQuery);\n        }\n        query_options = {\n          limit: options_limit\n        };\n        if (sort && _.isObject(sort)) {\n          query_options.sort = sort;\n        }\n        if (collection) {\n          try {\n            records = collection.find(query, query_options).fetch();\n            results = [];\n            _.each(records, function(record) {\n              return results.push({\n                label: record[name_field_key],\n                value: record._id\n              });\n            });\n            return results;\n          } catch (error) {\n            e = error;\n            throw new Meteor.Error(500, e.message + \"-->\" + JSON.stringify(options));\n          }\n        }\n      }\n    }\n    return [];\n  }\n});\n","Creator.getInitWidthPercent = (object_name, columns) ->\n\t_schema = Creator.getSchema(object_name)?._schema\n\tcolumn_num = 0\n\tif _schema\n\t\t_.each columns, (field_name) ->\n\t\t\tfield = _.pick(_schema, field_name)\n\t\t\tis_wide = field[field_name]?.autoform?.is_wide\n\t\t\tif is_wide\n\t\t\t\tcolumn_num += 2\n\t\t\telse\n\t\t\t\tcolumn_num += 1\n\n\t\tinit_width_percent = 100 / column_num\n\t\treturn init_width_percent\n\nCreator.getFieldIsWide = (object_name, field_name) ->\n\t_schema = Creator.getSchema(object_name)._schema\n\tif _schema\n\t\tfield = _.pick(_schema, field_name)\n\t\tis_wide = field[field_name]?.autoform?.is_wide\n\t\treturn is_wide\n\nCreator.getTabularOrder = (object_name, list_view_id, columns) ->\n\tsetting = Creator.Collections?.settings?.findOne({object_name: object_name, record_id: \"object_listviews\"})\n\tobj = Creator.getObject(object_name)\n\tcolumns = _.map columns, (column)->\n\t\tfield = obj.fields[column]\n\t\tif field?.type and !field.hidden\n\t\t\treturn column\n\t\telse\n\t\t\treturn undefined\n\tcolumns = _.compact columns\n\tif setting and setting.settings\n\t\tsort = setting.settings[list_view_id]?.sort || []\n\t\tsort = _.map sort, (order)->\n\t\t\tkey = order[0]\n\t\t\tindex = _.indexOf(columns, key)\n\t\t\torder[0] = index + 1\n\t\t\treturn order\n\t\treturn sort\n\treturn []\n\n\nCreator.initListViews = (object_name)->\n\tobject = Creator.getObject(object_name)\n\tcolumns = Creator.getObjectDefaultColumns(object_name) || [\"name\"]\n\textra_columns = [\"owner\"]\n\tdefault_extra_columns = Creator.getObjectDefaultExtraColumns(object_name) || [\"owner\"]\n\tif default_extra_columns\n\t\textra_columns = _.union extra_columns, default_extra_columns\n\n\torder = Creator.getObjectDefaultSort(object_name) || []\n\tif Meteor.isClient\n\t\tCreator.TabularSelectedIds?[object_name] = []\n\nCreator.convertListView = (default_view, list_view, list_view_name)->\n\tdefault_columns = default_view?.columns\n\tdefault_mobile_columns = default_view?.mobile_columns\n\tunless list_view\n\t\treturn\n\toitem = _.clone(list_view)\n\tif !_.has(oitem, \"name\")\n\t\toitem.name = list_view_name\n\tif !oitem.columns\n\t\tif default_columns\n\t\t\toitem.columns = default_columns\n\tif !oitem.columns\n\t\toitem.columns = [\"name\"]\n\tif !oitem.mobile_columns\n\t\tif default_mobile_columns\n\t\t\toitem.mobile_columns = default_mobile_columns\n\n\tif Meteor.isClient\n\t\tif Creator.isCloudAdminSpace(Session.get(\"spaceId\")) && !_.include(oitem.columns, 'space')\n\t\t\toitem.columns.push('space')\n\n\n\tif !oitem.filter_scope\n\t\t# listview视图的filter_scope默认值改为space #131\n\t\toitem.filter_scope = \"space\"\n\n\tif !_.has(oitem, \"_id\")\n\t\toitem._id = list_view_name\n\telse\n\t\toitem.label = oitem.label || list_view.name\n\n\tif _.isString(oitem.options)\n\t\toitem.options = JSON.parse(oitem.options)\n\n\t_.forEach oitem.filters, (filter, _index)->\n\t\tif !_.isArray(filter) && _.isObject(filter)\n\t\t\tif Meteor.isServer\n\t\t\t\tif _.isFunction(filter?.value)\n\t\t\t\t\tfilter._value = filter.value.toString()\n\t\t\telse\n\t\t\t\tif _.isString(filter?._value)\n\t\t\t\t\tfilter.value = Creator.eval(\"(#{filter._value})\")\n\treturn oitem\n\n\nif Meteor.isClient\n\tCreator.getRelatedList = (object_name)->\n\t\tunless object_name\n\t\t\treturn\n\t\trelatedListObjects = {}\n\t\trelatedListNames = []\n\t\tobjectLayoutRelatedListObjects = [];\n\t\t_object = Creator.getObject(object_name)\n\t\tif _object\n\t\t\tlayoutRelatedList = _object.related_lists;\n\t\t\t# layoutRelatedList 是数组就表示配置过页面布局，就启用页面布局的相关子表。\n\t\t\tif _.isArray layoutRelatedList\n\t\t\t\t_.each layoutRelatedList, (item)->\n\t\t\t\t\treObjectName = item.related_field_fullname.split('.')[0]\n\t\t\t\t\treFieldName = item.related_field_fullname.split('.')[1]\n\t\t\t\t\twrite_requires_master_read = Creator.getObject(reObjectName)?.fields[reFieldName]?.write_requires_master_read\n\t\t\t\t\trelated =\n\t\t\t\t\t\tobject_name: reObjectName\n\t\t\t\t\t\tcolumns: item.field_names\n\t\t\t\t\t\tmobile_columns: item.field_names\n\t\t\t\t\t\tis_file: reObjectName == \"cms_files\"\n\t\t\t\t\t\tfiltersFunction: item.filters\n\t\t\t\t\t\tsort: item.sort\n\t\t\t\t\t\trelated_field_name: reFieldName\n\t\t\t\t\t\tcustomRelatedListObject: true\n\t\t\t\t\t\twrite_requires_master_read: write_requires_master_read\n\t\t\t\t\t\tlabel: item.label\n\t\t\t\t\t\tactions: item.buttons\n\t\t\t\t\t\tvisible_on: item.visible_on\n\t\t\t\t\t\tpage_size: item.page_size\n\t\t\t\t\tobjectLayoutRelatedListObjects.push(related)\n\t\t\t\treturn objectLayoutRelatedListObjects;\n\t\t\trelatedList = _object.relatedList\n\t\t\tif !_.isEmpty relatedList\n\t\t\t\t_.each relatedList, (objOrName)->\n\t\t\t\t\tif _.isObject objOrName\n\t\t\t\t\t\trelated =\n\t\t\t\t\t\t\tobject_name: objOrName.objectName\n\t\t\t\t\t\t\tcolumns: objOrName.columns\n\t\t\t\t\t\t\tmobile_columns: objOrName.mobile_columns\n\t\t\t\t\t\t\tis_file: objOrName.objectName == \"cms_files\"\n\t\t\t\t\t\t\tfiltersFunction: objOrName.filters\n\t\t\t\t\t\t\tsort: objOrName.sort\n\t\t\t\t\t\t\trelated_field_name: ''\n\t\t\t\t\t\t\tcustomRelatedListObject: true\n\t\t\t\t\t\t\tlabel: objOrName.label\n\t\t\t\t\t\t\tactions: objOrName.actions\n\t\t\t\t\t\t\tpage_size: objOrName.page_size\n\t\t\t\t\t\trelatedListObjects[objOrName.objectName] = related\n\t\t\t\t\t\trelatedListNames.push objOrName.objectName\n\t\t\t\t\telse if _.isString objOrName\n\t\t\t\t\t\trelatedListNames.push objOrName\n\n\t\tmapList = {}\n\t\trelated_objects = Creator.getRelatedObjects(object_name)\n\t\t_.each related_objects, (related_object_item) ->\n\t\t\tif !related_object_item?.object_name\n\t\t\t\treturn\n\t\t\trelated_object_name = related_object_item.object_name\n\t\t\trelated_field_name = related_object_item.foreign_key\n\t\t\twrite_requires_master_read = related_object_item.write_requires_master_read\n\t\t\trelated_object = Creator.getObject(related_object_name)\n\t\t\tunless related_object\n\t\t\t\treturn\n\t\t\tcolumns = Creator.getObjectFirstListViewColumns(related_object_name) || [\"name\"]\n\t\t\tcolumns = _.without(columns, related_field_name)\n\t\t\tmobile_columns = Creator.getObjectFirstListViewColumns(related_object_name, true) || [\"name\"]\n\t\t\tmobile_columns = _.without(mobile_columns, related_field_name)\n\n\t\t\torder = Creator.getObjectDefaultSort(related_object_name)\n\t\t\ttabular_order = Creator.transformSortToTabular(order, columns)\n\n\t\t\tif /\\w+\\.\\$\\.\\w+/g.test(related_field_name)\n\t\t\t\t# object类型带子属性的related_field_name要去掉中间的美元符号，否则显示不出字段值\n\t\t\t\trelated_field_name = related_field_name.replace(/\\$\\./,\"\")\n\t\t\trelated =\n\t\t\t\tobject_name: related_object_name\n\t\t\t\tcolumns: columns\n\t\t\t\tmobile_columns: mobile_columns\n\t\t\t\trelated_field_name: related_field_name\n\t\t\t\tis_file: related_object_name == \"cms_files\"\n\t\t\t\twrite_requires_master_read: write_requires_master_read\n\n\t\t\trelatedObject = relatedListObjects[related_object_name]\n\t\t\tif relatedObject\n\t\t\t\tif relatedObject.columns\n\t\t\t\t\trelated.columns = relatedObject.columns\n\t\t\t\tif relatedObject.mobile_columns\n\t\t\t\t\trelated.mobile_columns = relatedObject.mobile_columns\n\t\t\t\tif relatedObject.sort\n\t\t\t\t\trelated.sort = relatedObject.sort\n\t\t\t\tif relatedObject.filtersFunction\n\t\t\t\t\trelated.filtersFunction = relatedObject.filtersFunction\n\t\t\t\tif relatedObject.customRelatedListObject\n\t\t\t\t\trelated.customRelatedListObject = relatedObject.customRelatedListObject\n\t\t\t\tif relatedObject.label\n\t\t\t\t\trelated.label = relatedObject.label\n\t\t\t\tif relatedObject.page_size\n\t\t\t\t\trelated.page_size = relatedObject.page_size\n\t\t\t\tdelete relatedListObjects[related_object_name]\n\n\t\t\tmapList[related.object_name] = related\n\n\n\t\tspaceId = Session.get(\"spaceId\")\n\t\tuserId = Meteor.userId()\n\t\trelated_object_names = _.pluck(_.values(relatedListObjects), \"object_name\")\n\t\tpermissions = Creator.getPermissions(object_name, spaceId, userId)\n\t\tunrelated_objects = permissions.unrelated_objects\n\t\trelated_object_names = _.difference related_object_names, unrelated_objects\n\t\t_.each relatedListObjects, (v, related_object_name) ->\n\t\t\tisActive = related_object_names.indexOf(related_object_name) > -1\n\t\t\tallowRead = Creator.getPermissions(related_object_name, spaceId, userId)?.allowRead\n\t\t\tif isActive && allowRead\n\t\t\t\tmapList[related_object_name] = v\n\n\t\tlist = []\n\t\tif _.isEmpty relatedListNames\n\t\t\tlist =  _.values mapList\n\t\telse\n\t\t\t_.each relatedListNames, (objectName) ->\n\t\t\t\tif mapList[objectName]\n\t\t\t\t\tlist.push mapList[objectName]\n\n\t\tif _.has(_object, 'allow_relatedList')\n\t\t\tlist = _.filter list, (item)->\n\t\t\t\treturn _.include(_object.allow_relatedList, item.object_name)\n\n\t\treturn list\n\nCreator.getObjectFirstListView = (object_name)->\n\treturn _.first(Creator.getListViews(object_name))\n\n### \n\t取出list_view_id对应的视图，如果不存在或者没有权限，就返回第一个视图\n\texac为true时，需要强制按list_view_id精确查找，不默认返回第一个视图\n###\nCreator.getListView = (object_name, list_view_id, exac)->\n\tif Meteor.isClient\n\t\tif !object_name\n\t\t\tobject_name = Session.get(\"object_name\")\n\t\tif !list_view_id\n\t\t\tlist_view_id = Session.get(\"list_view_id\")\n\tobject = Creator.getObject(object_name)\n\tif !object\n\t\treturn\n\tlistViews = Creator.getListViews(object_name)\n\tunless listViews?.length\n\t\treturn\n\tlist_view = _.find(listViews, (item)-> return item._id == list_view_id || item.name == list_view_id)\n\tunless list_view\n\t\t# 如果不需要强制按list_view_id精确查找，则默认返回第一个视图，反之返回空\n\t\tif exac\n\t\t\treturn\n\t\telse\n\t\t\tlist_view = listViews[0]\n\treturn list_view\n\n#获取list_view_id对应的视图是否是最近查看视图\nCreator.getListViewIsRecent = (object_name, list_view_id)->\n\tif Meteor.isClient\n\t\tif !object_name\n\t\t\tobject_name = Session.get(\"object_name\")\n\t\tif !list_view_id\n\t\t\tlist_view_id = Session.get(\"list_view_id\")\n\tif typeof(list_view_id) == \"string\"\n\t\tobject = Creator.getObject(object_name)\n\t\tif !object\n\t\t\treturn\n\t\tlistView = _.findWhere(object.list_views,{_id: list_view_id})\n\telse\n\t\tlistView = list_view_id\n\treturn listView?.name == \"recent\"\n\n\n###\n    从columns参数中过滤出用于手机端显示的columns\n\t规则：\n\t1.优先把columns中的name字段排在第一个\n\t2.最多只返回4个字段\n\t3.考虑宽字段占用整行规则条件下，最多只返回两行\n###\nCreator.pickObjectMobileColumns = (object_name, columns)->\n\tresult = []\n\tmaxRows = 2 \n\tmaxCount = maxRows * 2\n\tcount = 0\n\tobject = Creator.getObject(object_name)\n\tfields = object.fields\n\tunless object\n\t\treturn columns\n\tnameKey = object.NAME_FIELD_KEY\n\tisNameColumn = (item)->\n\t\tif _.isObject(item)\n\t\t\treturn item.field == nameKey\n\t\telse\n\t\t\treturn item == nameKey\n\tgetField = (item)->\n\t\tif _.isObject(item)\n\t\t\treturn fields[item.field]\n\t\telse\n\t\t\treturn fields[item]\n\tif nameKey\n\t\tnameColumn = columns.find (item)->\n\t\t\treturn isNameColumn(item)\n\tif nameColumn\n\t\tfield = getField(nameColumn)\n\t\titemCount = if field.is_wide then 2 else 1\n\t\tcount += itemCount\n\t\tresult.push nameColumn\n\tcolumns.forEach (item)->\n\t\tfield = getField(item)\n\t\tunless field\n\t\t\treturn\n\t\titemCount = if field.is_wide then 2 else 1\n\t\tif count < maxCount and result.length < maxCount and !isNameColumn(item)\n\t\t\tcount += itemCount\n\t\t\tif count <= maxCount\n\t\t\t\tresult.push item\n\t\n\treturn result\n\n###\n    获取默认视图\n###\nCreator.getObjectDefaultView = (object_name)->\n\tobject = Creator.getObject(object_name)\n\tif !object\n\t\tobject = Creator.Objects[object_name]\n\tif object?.list_views?.default\n\t\t#TODO 此代码只是暂时兼容以前code中定义的default视图，待code中的default清理完成后，需要删除此代码\n\t\tdefaultView = object.list_views.default\n\telse\n\t\t_.each object?.list_views, (list_view, key)->\n\t\t\tif list_view.name == \"all\" || key == \"all\"\n\t\t\t\tdefaultView = list_view\n\treturn defaultView;\n\n###\n    获取对象的列表默认显示字段\n###\nCreator.getObjectDefaultColumns = (object_name, use_mobile_columns)->\n\tdefaultView = Creator.getObjectDefaultView(object_name)\n\tcolumns = defaultView?.columns\n\tif use_mobile_columns\n\t\tif defaultView?.mobile_columns\n\t\t\tcolumns = defaultView.mobile_columns\n\t\telse if columns\n\t\t\tcolumns = Creator.pickObjectMobileColumns(object_name, columns)\n\treturn columns\n\n###\n    获取对象的列表第一个视图显示的字段\n###\nCreator.getObjectFirstListViewColumns = (object_name, use_mobile_columns)->\n\tdefaultView = Creator.getObjectFirstListView(object_name)\n\tcolumns = defaultView?.columns\n\tif use_mobile_columns\n\t\tif defaultView?.mobile_columns\n\t\t\tcolumns = defaultView.mobile_columns\n\t\telse if columns\n\t\t\tcolumns = Creator.pickObjectMobileColumns(object_name, columns)\n\treturn columns\n\n###\n\t获取对象的列表默认额外加载的字段\n###\nCreator.getObjectDefaultExtraColumns = (object_name)->\n\tdefaultView = Creator.getObjectDefaultView(object_name)\n\treturn defaultView?.extra_columns\n\n###\n\t获取对象的默认排序\n###\nCreator.getObjectDefaultSort = (object_name)->\n\tdefaultView = Creator.getObjectDefaultView(object_name)\n\tif defaultView\n\t\tif defaultView.sort\n\t\t\treturn defaultView.sort\n\t\telse\n\t\t\treturn [[\"created\", \"desc\"]]\n\n\n###\n    判断是否All view\n###\nCreator.isAllView = (list_view)->\n\treturn list_view?.name == \"all\"\n\n###\n    判断是否最近查看 view\n###\nCreator.isRecentView = (list_view)->\n\treturn list_view?.name == \"recent\"\n\n###\n    将sort转换为Tabular控件所需要的格式\n###\nCreator.transformSortToTabular = (sort, tabularColumns)->\n\ttabular_sort = []\n\t_.each sort, (item)->\n\t\tif _.isArray(item)\n\t\t\t# 兼容旧的数据格式[[\"field_name\", \"order\"]]\n\t\t\tif item.length == 1\n\t\t\t\tcolumn_index = tabularColumns.indexOf(item[0])\n\t\t\t\tif column_index > -1\n\t\t\t\t\ttabular_sort.push [column_index, \"asc\"]\n\t\t\telse if item.length == 2\n\t\t\t\tcolumn_index = tabularColumns.indexOf(item[0])\n\t\t\t\tif column_index > -1\n\t\t\t\t\ttabular_sort.push [column_index, item[1]]\n\t\telse if _.isObject(item)\n\t\t\t#新数据格式：[{field_name: , order: }]\n\t\t\tfield_name = item.field_name\n\t\t\torder = item.order\n\t\t\tif field_name && order\n\t\t\t\tcolumn_index = tabularColumns.indexOf(field_name)\n\t\t\t\tif column_index > -1\n\t\t\t\t\ttabular_sort.push [column_index, order]\n\n\treturn tabular_sort\n\n###\n    将sort转换为DevExpress控件所需要的格式\n###\nCreator.transformSortToDX = (sort)->\n\tdx_sort = []\n\t_.each sort, (item)->\n\t\tif _.isArray(item)\n\t\t\t#兼容旧格式：[[\"field_name\", \"order\"]]\n\t\t\tdx_sort.push(item)\n\t\telse if _.isObject(item)\n\t\t\t#新数据格式：[{field_name: , order: }]\n\t\t\tfield_name = item.field_name\n\t\t\torder = item.order\n\t\t\tif field_name && order\n\t\t\t\tdx_sort.push [field_name, order]\n\n\treturn dx_sort\n","Creator.getInitWidthPercent = function(object_name, columns) {\n  var _schema, column_num, init_width_percent, ref;\n  _schema = (ref = Creator.getSchema(object_name)) != null ? ref._schema : void 0;\n  column_num = 0;\n  if (_schema) {\n    _.each(columns, function(field_name) {\n      var field, is_wide, ref1, ref2;\n      field = _.pick(_schema, field_name);\n      is_wide = (ref1 = field[field_name]) != null ? (ref2 = ref1.autoform) != null ? ref2.is_wide : void 0 : void 0;\n      if (is_wide) {\n        return column_num += 2;\n      } else {\n        return column_num += 1;\n      }\n    });\n    init_width_percent = 100 / column_num;\n    return init_width_percent;\n  }\n};\n\nCreator.getFieldIsWide = function(object_name, field_name) {\n  var _schema, field, is_wide, ref, ref1;\n  _schema = Creator.getSchema(object_name)._schema;\n  if (_schema) {\n    field = _.pick(_schema, field_name);\n    is_wide = (ref = field[field_name]) != null ? (ref1 = ref.autoform) != null ? ref1.is_wide : void 0 : void 0;\n    return is_wide;\n  }\n};\n\nCreator.getTabularOrder = function(object_name, list_view_id, columns) {\n  var obj, ref, ref1, ref2, setting, sort;\n  setting = (ref = Creator.Collections) != null ? (ref1 = ref.settings) != null ? ref1.findOne({\n    object_name: object_name,\n    record_id: \"object_listviews\"\n  }) : void 0 : void 0;\n  obj = Creator.getObject(object_name);\n  columns = _.map(columns, function(column) {\n    var field;\n    field = obj.fields[column];\n    if ((field != null ? field.type : void 0) && !field.hidden) {\n      return column;\n    } else {\n      return void 0;\n    }\n  });\n  columns = _.compact(columns);\n  if (setting && setting.settings) {\n    sort = ((ref2 = setting.settings[list_view_id]) != null ? ref2.sort : void 0) || [];\n    sort = _.map(sort, function(order) {\n      var index, key;\n      key = order[0];\n      index = _.indexOf(columns, key);\n      order[0] = index + 1;\n      return order;\n    });\n    return sort;\n  }\n  return [];\n};\n\nCreator.initListViews = function(object_name) {\n  var columns, default_extra_columns, extra_columns, object, order, ref;\n  object = Creator.getObject(object_name);\n  columns = Creator.getObjectDefaultColumns(object_name) || [\"name\"];\n  extra_columns = [\"owner\"];\n  default_extra_columns = Creator.getObjectDefaultExtraColumns(object_name) || [\"owner\"];\n  if (default_extra_columns) {\n    extra_columns = _.union(extra_columns, default_extra_columns);\n  }\n  order = Creator.getObjectDefaultSort(object_name) || [];\n  if (Meteor.isClient) {\n    return (ref = Creator.TabularSelectedIds) != null ? ref[object_name] = [] : void 0;\n  }\n};\n\nCreator.convertListView = function(default_view, list_view, list_view_name) {\n  var default_columns, default_mobile_columns, oitem;\n  default_columns = default_view != null ? default_view.columns : void 0;\n  default_mobile_columns = default_view != null ? default_view.mobile_columns : void 0;\n  if (!list_view) {\n    return;\n  }\n  oitem = _.clone(list_view);\n  if (!_.has(oitem, \"name\")) {\n    oitem.name = list_view_name;\n  }\n  if (!oitem.columns) {\n    if (default_columns) {\n      oitem.columns = default_columns;\n    }\n  }\n  if (!oitem.columns) {\n    oitem.columns = [\"name\"];\n  }\n  if (!oitem.mobile_columns) {\n    if (default_mobile_columns) {\n      oitem.mobile_columns = default_mobile_columns;\n    }\n  }\n  if (Meteor.isClient) {\n    if (Creator.isCloudAdminSpace(Session.get(\"spaceId\")) && !_.include(oitem.columns, 'space')) {\n      oitem.columns.push('space');\n    }\n  }\n  if (!oitem.filter_scope) {\n    oitem.filter_scope = \"space\";\n  }\n  if (!_.has(oitem, \"_id\")) {\n    oitem._id = list_view_name;\n  } else {\n    oitem.label = oitem.label || list_view.name;\n  }\n  if (_.isString(oitem.options)) {\n    oitem.options = JSON.parse(oitem.options);\n  }\n  _.forEach(oitem.filters, function(filter, _index) {\n    if (!_.isArray(filter) && _.isObject(filter)) {\n      if (Meteor.isServer) {\n        if (_.isFunction(filter != null ? filter.value : void 0)) {\n          return filter._value = filter.value.toString();\n        }\n      } else {\n        if (_.isString(filter != null ? filter._value : void 0)) {\n          return filter.value = Creator[\"eval\"](\"(\" + filter._value + \")\");\n        }\n      }\n    }\n  });\n  return oitem;\n};\n\nif (Meteor.isClient) {\n  Creator.getRelatedList = function(object_name) {\n    var _object, layoutRelatedList, list, mapList, objectLayoutRelatedListObjects, permissions, relatedList, relatedListNames, relatedListObjects, related_object_names, related_objects, spaceId, unrelated_objects, userId;\n    if (!object_name) {\n      return;\n    }\n    relatedListObjects = {};\n    relatedListNames = [];\n    objectLayoutRelatedListObjects = [];\n    _object = Creator.getObject(object_name);\n    if (_object) {\n      layoutRelatedList = _object.related_lists;\n      if (_.isArray(layoutRelatedList)) {\n        _.each(layoutRelatedList, function(item) {\n          var reFieldName, reObjectName, ref, ref1, related, write_requires_master_read;\n          reObjectName = item.related_field_fullname.split('.')[0];\n          reFieldName = item.related_field_fullname.split('.')[1];\n          write_requires_master_read = (ref = Creator.getObject(reObjectName)) != null ? (ref1 = ref.fields[reFieldName]) != null ? ref1.write_requires_master_read : void 0 : void 0;\n          related = {\n            object_name: reObjectName,\n            columns: item.field_names,\n            mobile_columns: item.field_names,\n            is_file: reObjectName === \"cms_files\",\n            filtersFunction: item.filters,\n            sort: item.sort,\n            related_field_name: reFieldName,\n            customRelatedListObject: true,\n            write_requires_master_read: write_requires_master_read,\n            label: item.label,\n            actions: item.buttons,\n            visible_on: item.visible_on,\n            page_size: item.page_size\n          };\n          return objectLayoutRelatedListObjects.push(related);\n        });\n        return objectLayoutRelatedListObjects;\n      }\n      relatedList = _object.relatedList;\n      if (!_.isEmpty(relatedList)) {\n        _.each(relatedList, function(objOrName) {\n          var related;\n          if (_.isObject(objOrName)) {\n            related = {\n              object_name: objOrName.objectName,\n              columns: objOrName.columns,\n              mobile_columns: objOrName.mobile_columns,\n              is_file: objOrName.objectName === \"cms_files\",\n              filtersFunction: objOrName.filters,\n              sort: objOrName.sort,\n              related_field_name: '',\n              customRelatedListObject: true,\n              label: objOrName.label,\n              actions: objOrName.actions,\n              page_size: objOrName.page_size\n            };\n            relatedListObjects[objOrName.objectName] = related;\n            return relatedListNames.push(objOrName.objectName);\n          } else if (_.isString(objOrName)) {\n            return relatedListNames.push(objOrName);\n          }\n        });\n      }\n    }\n    mapList = {};\n    related_objects = Creator.getRelatedObjects(object_name);\n    _.each(related_objects, function(related_object_item) {\n      var columns, mobile_columns, order, related, relatedObject, related_field_name, related_object, related_object_name, tabular_order, write_requires_master_read;\n      if (!(related_object_item != null ? related_object_item.object_name : void 0)) {\n        return;\n      }\n      related_object_name = related_object_item.object_name;\n      related_field_name = related_object_item.foreign_key;\n      write_requires_master_read = related_object_item.write_requires_master_read;\n      related_object = Creator.getObject(related_object_name);\n      if (!related_object) {\n        return;\n      }\n      columns = Creator.getObjectFirstListViewColumns(related_object_name) || [\"name\"];\n      columns = _.without(columns, related_field_name);\n      mobile_columns = Creator.getObjectFirstListViewColumns(related_object_name, true) || [\"name\"];\n      mobile_columns = _.without(mobile_columns, related_field_name);\n      order = Creator.getObjectDefaultSort(related_object_name);\n      tabular_order = Creator.transformSortToTabular(order, columns);\n      if (/\\w+\\.\\$\\.\\w+/g.test(related_field_name)) {\n        related_field_name = related_field_name.replace(/\\$\\./, \"\");\n      }\n      related = {\n        object_name: related_object_name,\n        columns: columns,\n        mobile_columns: mobile_columns,\n        related_field_name: related_field_name,\n        is_file: related_object_name === \"cms_files\",\n        write_requires_master_read: write_requires_master_read\n      };\n      relatedObject = relatedListObjects[related_object_name];\n      if (relatedObject) {\n        if (relatedObject.columns) {\n          related.columns = relatedObject.columns;\n        }\n        if (relatedObject.mobile_columns) {\n          related.mobile_columns = relatedObject.mobile_columns;\n        }\n        if (relatedObject.sort) {\n          related.sort = relatedObject.sort;\n        }\n        if (relatedObject.filtersFunction) {\n          related.filtersFunction = relatedObject.filtersFunction;\n        }\n        if (relatedObject.customRelatedListObject) {\n          related.customRelatedListObject = relatedObject.customRelatedListObject;\n        }\n        if (relatedObject.label) {\n          related.label = relatedObject.label;\n        }\n        if (relatedObject.page_size) {\n          related.page_size = relatedObject.page_size;\n        }\n        delete relatedListObjects[related_object_name];\n      }\n      return mapList[related.object_name] = related;\n    });\n    spaceId = Session.get(\"spaceId\");\n    userId = Meteor.userId();\n    related_object_names = _.pluck(_.values(relatedListObjects), \"object_name\");\n    permissions = Creator.getPermissions(object_name, spaceId, userId);\n    unrelated_objects = permissions.unrelated_objects;\n    related_object_names = _.difference(related_object_names, unrelated_objects);\n    _.each(relatedListObjects, function(v, related_object_name) {\n      var allowRead, isActive, ref;\n      isActive = related_object_names.indexOf(related_object_name) > -1;\n      allowRead = (ref = Creator.getPermissions(related_object_name, spaceId, userId)) != null ? ref.allowRead : void 0;\n      if (isActive && allowRead) {\n        return mapList[related_object_name] = v;\n      }\n    });\n    list = [];\n    if (_.isEmpty(relatedListNames)) {\n      list = _.values(mapList);\n    } else {\n      _.each(relatedListNames, function(objectName) {\n        if (mapList[objectName]) {\n          return list.push(mapList[objectName]);\n        }\n      });\n    }\n    if (_.has(_object, 'allow_relatedList')) {\n      list = _.filter(list, function(item) {\n        return _.include(_object.allow_relatedList, item.object_name);\n      });\n    }\n    return list;\n  };\n}\n\nCreator.getObjectFirstListView = function(object_name) {\n  return _.first(Creator.getListViews(object_name));\n};\n\n\n/* \n\t取出list_view_id对应的视图，如果不存在或者没有权限，就返回第一个视图\n\texac为true时，需要强制按list_view_id精确查找，不默认返回第一个视图\n */\n\nCreator.getListView = function(object_name, list_view_id, exac) {\n  var listViews, list_view, object;\n  if (Meteor.isClient) {\n    if (!object_name) {\n      object_name = Session.get(\"object_name\");\n    }\n    if (!list_view_id) {\n      list_view_id = Session.get(\"list_view_id\");\n    }\n  }\n  object = Creator.getObject(object_name);\n  if (!object) {\n    return;\n  }\n  listViews = Creator.getListViews(object_name);\n  if (!(listViews != null ? listViews.length : void 0)) {\n    return;\n  }\n  list_view = _.find(listViews, function(item) {\n    return item._id === list_view_id || item.name === list_view_id;\n  });\n  if (!list_view) {\n    if (exac) {\n      return;\n    } else {\n      list_view = listViews[0];\n    }\n  }\n  return list_view;\n};\n\nCreator.getListViewIsRecent = function(object_name, list_view_id) {\n  var listView, object;\n  if (Meteor.isClient) {\n    if (!object_name) {\n      object_name = Session.get(\"object_name\");\n    }\n    if (!list_view_id) {\n      list_view_id = Session.get(\"list_view_id\");\n    }\n  }\n  if (typeof list_view_id === \"string\") {\n    object = Creator.getObject(object_name);\n    if (!object) {\n      return;\n    }\n    listView = _.findWhere(object.list_views, {\n      _id: list_view_id\n    });\n  } else {\n    listView = list_view_id;\n  }\n  return (listView != null ? listView.name : void 0) === \"recent\";\n};\n\n\n/*\n    从columns参数中过滤出用于手机端显示的columns\n\t规则：\n\t1.优先把columns中的name字段排在第一个\n\t2.最多只返回4个字段\n\t3.考虑宽字段占用整行规则条件下，最多只返回两行\n */\n\nCreator.pickObjectMobileColumns = function(object_name, columns) {\n  var count, field, fields, getField, isNameColumn, itemCount, maxCount, maxRows, nameColumn, nameKey, object, result;\n  result = [];\n  maxRows = 2;\n  maxCount = maxRows * 2;\n  count = 0;\n  object = Creator.getObject(object_name);\n  fields = object.fields;\n  if (!object) {\n    return columns;\n  }\n  nameKey = object.NAME_FIELD_KEY;\n  isNameColumn = function(item) {\n    if (_.isObject(item)) {\n      return item.field === nameKey;\n    } else {\n      return item === nameKey;\n    }\n  };\n  getField = function(item) {\n    if (_.isObject(item)) {\n      return fields[item.field];\n    } else {\n      return fields[item];\n    }\n  };\n  if (nameKey) {\n    nameColumn = columns.find(function(item) {\n      return isNameColumn(item);\n    });\n  }\n  if (nameColumn) {\n    field = getField(nameColumn);\n    itemCount = field.is_wide ? 2 : 1;\n    count += itemCount;\n    result.push(nameColumn);\n  }\n  columns.forEach(function(item) {\n    field = getField(item);\n    if (!field) {\n      return;\n    }\n    itemCount = field.is_wide ? 2 : 1;\n    if (count < maxCount && result.length < maxCount && !isNameColumn(item)) {\n      count += itemCount;\n      if (count <= maxCount) {\n        return result.push(item);\n      }\n    }\n  });\n  return result;\n};\n\n\n/*\n    获取默认视图\n */\n\nCreator.getObjectDefaultView = function(object_name) {\n  var defaultView, object, ref;\n  object = Creator.getObject(object_name);\n  if (!object) {\n    object = Creator.Objects[object_name];\n  }\n  if (object != null ? (ref = object.list_views) != null ? ref[\"default\"] : void 0 : void 0) {\n    defaultView = object.list_views[\"default\"];\n  } else {\n    _.each(object != null ? object.list_views : void 0, function(list_view, key) {\n      if (list_view.name === \"all\" || key === \"all\") {\n        return defaultView = list_view;\n      }\n    });\n  }\n  return defaultView;\n};\n\n\n/*\n    获取对象的列表默认显示字段\n */\n\nCreator.getObjectDefaultColumns = function(object_name, use_mobile_columns) {\n  var columns, defaultView;\n  defaultView = Creator.getObjectDefaultView(object_name);\n  columns = defaultView != null ? defaultView.columns : void 0;\n  if (use_mobile_columns) {\n    if (defaultView != null ? defaultView.mobile_columns : void 0) {\n      columns = defaultView.mobile_columns;\n    } else if (columns) {\n      columns = Creator.pickObjectMobileColumns(object_name, columns);\n    }\n  }\n  return columns;\n};\n\n\n/*\n    获取对象的列表第一个视图显示的字段\n */\n\nCreator.getObjectFirstListViewColumns = function(object_name, use_mobile_columns) {\n  var columns, defaultView;\n  defaultView = Creator.getObjectFirstListView(object_name);\n  columns = defaultView != null ? defaultView.columns : void 0;\n  if (use_mobile_columns) {\n    if (defaultView != null ? defaultView.mobile_columns : void 0) {\n      columns = defaultView.mobile_columns;\n    } else if (columns) {\n      columns = Creator.pickObjectMobileColumns(object_name, columns);\n    }\n  }\n  return columns;\n};\n\n\n/*\n\t获取对象的列表默认额外加载的字段\n */\n\nCreator.getObjectDefaultExtraColumns = function(object_name) {\n  var defaultView;\n  defaultView = Creator.getObjectDefaultView(object_name);\n  return defaultView != null ? defaultView.extra_columns : void 0;\n};\n\n\n/*\n\t获取对象的默认排序\n */\n\nCreator.getObjectDefaultSort = function(object_name) {\n  var defaultView;\n  defaultView = Creator.getObjectDefaultView(object_name);\n  if (defaultView) {\n    if (defaultView.sort) {\n      return defaultView.sort;\n    } else {\n      return [[\"created\", \"desc\"]];\n    }\n  }\n};\n\n\n/*\n    判断是否All view\n */\n\nCreator.isAllView = function(list_view) {\n  return (list_view != null ? list_view.name : void 0) === \"all\";\n};\n\n\n/*\n    判断是否最近查看 view\n */\n\nCreator.isRecentView = function(list_view) {\n  return (list_view != null ? list_view.name : void 0) === \"recent\";\n};\n\n\n/*\n    将sort转换为Tabular控件所需要的格式\n */\n\nCreator.transformSortToTabular = function(sort, tabularColumns) {\n  var tabular_sort;\n  tabular_sort = [];\n  _.each(sort, function(item) {\n    var column_index, field_name, order;\n    if (_.isArray(item)) {\n      if (item.length === 1) {\n        column_index = tabularColumns.indexOf(item[0]);\n        if (column_index > -1) {\n          return tabular_sort.push([column_index, \"asc\"]);\n        }\n      } else if (item.length === 2) {\n        column_index = tabularColumns.indexOf(item[0]);\n        if (column_index > -1) {\n          return tabular_sort.push([column_index, item[1]]);\n        }\n      }\n    } else if (_.isObject(item)) {\n      field_name = item.field_name;\n      order = item.order;\n      if (field_name && order) {\n        column_index = tabularColumns.indexOf(field_name);\n        if (column_index > -1) {\n          return tabular_sort.push([column_index, order]);\n        }\n      }\n    }\n  });\n  return tabular_sort;\n};\n\n\n/*\n    将sort转换为DevExpress控件所需要的格式\n */\n\nCreator.transformSortToDX = function(sort) {\n  var dx_sort;\n  dx_sort = [];\n  _.each(sort, function(item) {\n    var field_name, order;\n    if (_.isArray(item)) {\n      return dx_sort.push(item);\n    } else if (_.isObject(item)) {\n      field_name = item.field_name;\n      order = item.order;\n      if (field_name && order) {\n        return dx_sort.push([field_name, order]);\n      }\n    }\n  });\n  return dx_sort;\n};\n","SimpleSchema.RegEx.code = new RegExp('^[a-zA-Z_][a-zA-Z0-9_]*$')\n\nif Meteor.isClient\n\tMeteor.startup ()->\n\t\t_regExMessages = SimpleSchema._globalMessages.regEx || []\n\t\t_regExMessages.push {exp: SimpleSchema.RegEx.code, msg: \"[label] 只能以字母、_开头，且只能包含字母、数字、_\"}\n\t\tSimpleSchema.messages({\n\t\t\tregEx: _regExMessages,\n\t\t})","SimpleSchema.RegEx.code = new RegExp('^[a-zA-Z_][a-zA-Z0-9_]*$');\n\nif (Meteor.isClient) {\n  Meteor.startup(function() {\n    var _regExMessages;\n    _regExMessages = SimpleSchema._globalMessages.regEx || [];\n    _regExMessages.push({\n      exp: SimpleSchema.RegEx.code,\n      msg: \"[label] 只能以字母、_开头，且只能包含字母、数字、_\"\n    });\n    return SimpleSchema.messages({\n      regEx: _regExMessages\n    });\n  });\n}\n","SimpleSchema.RegEx.field = new RegExp('^[a-zA-Z_]\\\\w*(\\\\.\\\\$\\\\.\\\\w+)?[a-zA-Z0-9]*$')\n\nif Meteor.isClient\n\tMeteor.startup ()->\n\t\t_regExMessages = SimpleSchema._globalMessages.regEx || []\n\t\t_regExMessages.push {exp: SimpleSchema.RegEx.field, msg: \"[label] 只能以字母、_开头，.$.前后必须包含字符\"}\n\t\tSimpleSchema.messages({\n\t\t\tregEx: _regExMessages,\n\t\t})","SimpleSchema.RegEx.field = new RegExp('^[a-zA-Z_]\\\\w*(\\\\.\\\\$\\\\.\\\\w+)?[a-zA-Z0-9]*$');\n\nif (Meteor.isClient) {\n  Meteor.startup(function() {\n    var _regExMessages;\n    _regExMessages = SimpleSchema._globalMessages.regEx || [];\n    _regExMessages.push({\n      exp: SimpleSchema.RegEx.field,\n      msg: \"[label] 只能以字母、_开头，.$.前后必须包含字符\"\n    });\n    return SimpleSchema.messages({\n      regEx: _regExMessages\n    });\n  });\n}\n","// 因为meteor编译coffeescript会导致eval函数报错，所以单独写在一个js文件中。\nCreator.evalInContext = function(js, context) {\n    //# Return the results of the in-line anonymous function we .call with the passed context\n    return function() { \n    \treturn eval(js); \n\t}.call(context);\n}\n\n\nCreator.eval = function(js){\n\ttry{\n\t\treturn eval(js)\n\t}catch (e){\n\t\tconsole.error(e, js);\n\t}\n};","\tgetOption = (option)->\n\t\tfoo = option.split(\":\")\n\t\tif foo.length > 2\n\t\t\treturn {label: foo[0], value: foo[1], color: foo[2]}\n\t\telse if foo.length > 1\n\t\t\treturn {label: foo[0], value: foo[1]}\n\t\telse\n\t\t\treturn {label: foo[0], value: foo[0]}\n\n\tconvertField = (object_name, field_name, field, spaceId)->\n\t\tif Meteor.isServer && spaceId && field.type == 'select'\n\t\t\tcode = field.picklist || \"#{object_name}.#{field_name}\";\n\t\t\tif code\n\t\t\t\tpicklist = Creator.getPicklist(code, spaceId);\n\t\t\t\tif picklist\n\t\t\t\t\toptions = [];\n\t\t\t\t\tallOptions = [];\n\t\t\t\t\tpicklistOptions = Creator.getPickListOptions(picklist)\n\t\t\t\t\tpicklistOptions = _.sortBy(picklistOptions, 'sort_no')?.reverse();\n\t\t\t\t\t_.each picklistOptions, (item)->\n\t\t\t\t\t\tlabel = item.name\n\t\t\t\t\t\tvalue = item.value || item.name\n\t\t\t\t\t\tallOptions.push({label: label, value: value, enable: item.enable, color: item.color})\n\t\t\t\t\t\tif item.enable\n\t\t\t\t\t\t\toptions.push({label: label, value: value, color: item.color})\n\t\t\t\t\t\tif item.default\n\t\t\t\t\t\t\tfield.defaultValue = value\n\t\t\t\t\tif options.length > 0\n\t\t\t\t\t\tfield.options = options\n\t\t\t\t\tif allOptions.length > 0\n\t\t\t\t\t\tfield.allOptions = allOptions\n\t\treturn field;\n\n\tCreator.convertObject = (object, spaceId)->\n\t\tif !object\n\t\t\treturn\n\t\t_.forEach object.triggers, (trigger, key)->\n\n\t\t\tif (Meteor.isServer && trigger.on == \"server\") || (Meteor.isClient && trigger.on == \"client\")\n\t\t\t\t_todo_from_code = trigger?._todo\n\t\t\t\t_todo_from_db = trigger.todo\n\t\t\t\tif _todo_from_code && _.isString(_todo_from_code)\n\t\t\t\t\ttrigger.todo = Creator.eval(\"(#{_todo_from_code})\")\n\n\t\t\t\tif _todo_from_db && _.isString(_todo_from_db)\n\t\t\t\t\t#只有update时， fieldNames, modifier, options 才有值\n\t\t\t\t\t#TODO 控制可使用的变量，尤其是Collection\n\t\t\t\t\tif _todo_from_db.startsWith(\"function\")\n\t\t\t\t\t\ttrigger.todo = Creator.eval(\"(#{_todo_from_db})\")\n\t\t\t\t\telse\n\t\t\t\t\t\ttrigger.todo = Creator.eval(\"(function(userId, doc, fieldNames, modifier, options){#{_todo_from_db}})\")\n\n\t\t\tif Meteor.isServer && trigger.on == \"client\"\n\t\t\t\t_todo = trigger.todo\n\t\t\t\tif _todo && _.isFunction(_todo)\n\t\t\t\t\ttrigger._todo = _todo.toString()\n\n\t\tif Meteor.isClient\n\t\t\t_.forEach object.fields, (field, key)->\n\n\t\t\t\tif field.omit\n\t\t\t\t\t# omit字段完全隐藏不显示\n\t\t\t\t\tfield.hidden = true\n\n\t\t\t\tif field.required && field.readonly\n\t\t\t\t\t# 通用必填字段 #2952，必填字段设置为非只读\n\t\t\t\t\tfield.readonly = false\n\n\t\t\t\tsystemBaseFields = Creator.getSystemBaseFields()\n\t\t\t\tif systemBaseFields.indexOf(key) > -1\n\t\t\t\t\t# 强制创建人创建时间等字段为只读\n\t\t\t\t\tfield.readonly = true\n\n\t\t\t_.forEach object.actions, (action, key)->\n\t\t\t\t_todo_from_code = action?._todo\n\t\t\t\t_todo_from_db = action?.todo\n\t\t\t\tif _todo_from_code && _.isString(_todo_from_code)\n\t\t\t\t\t#TODO 控制可使用的变量\n\t\t\t\t\ttry\n\t\t\t\t\t\taction.todo = Creator.eval(\"(#{_todo_from_code})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"todo_from_code\", _todo_from_code\n\t\t\t\tif _todo_from_db && _.isString(_todo_from_db)\n\t\t\t\t\t#TODO 控制可使用的变量\n\t\t\t\t\ttry\n\t\t\t\t\t\tif _todo_from_db.startsWith(\"function\")\n\t\t\t\t\t\t\taction.todo = Creator.eval(\"(#{_todo_from_db})\")\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tif _.isFunction(Creator.actionsByName[_todo_from_db])\n\t\t\t\t\t\t\t\taction.todo = _todo_from_db\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\taction.todo = Creator.eval(\"(function(){#{_todo_from_db}})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"todo_from_db\", _todo_from_db, error\n\n\t\t\t\t_visible = action?._visible\n\t\t\t\tif _visible\n\t\t\t\t\ttry\n\t\t\t\t\t\tif _.isString(_visible)\n\t\t\t\t\t\t\t_visible = _visible.trim()\n\t\t\t\t\t\tif Steedos.isExpression(_visible)\n\t\t\t\t\t\t\t# 支持页面布局中写visible_on函数表达式，页面布局按钮的显示条件不生效 #3340\n\t\t\t\t\t\t\taction.visible = (object_name, record_id, record_permissions, record) ->\n\t\t\t\t\t\t\t\tglobalData = Object.assign({}, Creator.USER_CONTEXT, {now: new Date()})\n\t\t\t\t\t\t\t\treturn Steedos.parseSingleExpression(_visible, record, \"#\", globalData)\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\taction.visible = Creator.eval(\"(#{_visible})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"action.visible to function error: \", error, _visible\n\t\telse\n\t\t\t_.forEach object.actions, (action, key)->\n\t\t\t\t_todo = action?.todo\n\t\t\t\tif _todo && _.isFunction(_todo)\n\t\t\t\t\t#TODO 控制可使用的变量\n\t\t\t\t\taction._todo = _todo.toString()\n\n\t\t\t\t_visible = action?.visible\n\n\t\t\t\tif _visible && _.isFunction(_visible)\n\t\t\t\t\taction._visible = _visible.toString()\n\n\t\t_.forEach object.fields, (field, key)->\n\n\t\t\tfield = convertField(object.name, key, field, spaceId);\n\n\t\t\tif field.options && _.isString(field.options)\n\t\t\t\ttry\n\t\t\t\t\t_options = []\n\t\t\t\t\t#支持\\n或者英文逗号分割,\n\t\t\t\t\t_.forEach field.options.split(\"\\n\"), (option)->\n\t\t\t\t\t\tif option.indexOf(\",\")\n\t\t\t\t\t\t\toptions = option.split(\",\")\n\t\t\t\t\t\t\t_.forEach options, (_option)->\n\t\t\t\t\t\t\t\t_options.push(getOption(_option))\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t_options.push(getOption(option))\n\t\t\t\t\tfield.options = _options\n\t\t\t\tcatch error\n\t\t\t\t\tconsole.error \"Creator.convertFieldsOptions\", field.options, error\n\n\t\t\telse if field.options && _.isArray(field.options)\n\t\t\t\ttry\n\t\t\t\t\t_options = []\n\t\t\t\t\t#支持数组中直接定义每个选项的简版格式字符串\n\t\t\t\t\t_.forEach field.options, (option)->\n\t\t\t\t\t\tif _.isString(option)\n\t\t\t\t\t\t\t_options.push(getOption(option))\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t_options.push(option)\n\t\t\t\t\tfield.options = _options\n\t\t\t\tcatch error\n\t\t\t\t\tconsole.error \"Creator.convertFieldsOptions\", field.options, error\n\n\t\t\telse if field.options && !_.isFunction(field.options) && !_.isArray(field.options) && _.isObject(field.options)\n\t\t\t\t_options = []\n\t\t\t\t_.each field.options, (v, k)->\n\t\t\t\t\t_options.push {label: v, value: k}\n\t\t\t\tfield.options = _options\n\n\t\t\tif Meteor.isServer\n\t\t\t\toptions = field.options\n\t\t\t\tif options && _.isFunction(options)\n\t\t\t\t\tfield._options = field.options.toString()\n\t\t\telse\n\t\t\t\toptions = field._options\n\t\t\t\tif options && _.isString(options)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.options = Creator.eval(\"(#{options})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t\tif Meteor.isServer\n\t\t\t\tregEx = field.regEx\n\t\t\t\tif regEx\n\t\t\t\t\tfield._regEx = field.regEx.toString()\n\t\t\telse\n\t\t\t\tregEx = field._regEx\n\t\t\t\tif regEx\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.regEx = Creator.eval(\"(#{regEx})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t\tif Meteor.isServer\n\t\t\t\tmin = field.min\n\t\t\t\tif _.isFunction(min)\n\t\t\t\t\tfield._min = min.toString()\n\t\t\telse\n\t\t\t\tmin = field._min\n\t\t\t\tif _.isString(min)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.min = Creator.eval(\"(#{min})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t\tif Meteor.isServer\n\t\t\t\tmax = field.max\n\t\t\t\tif _.isFunction(max)\n\t\t\t\t\tfield._max = max.toString()\n\t\t\telse\n\t\t\t\tmax = field._max\n\t\t\t\tif _.isString(max)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.max = Creator.eval(\"(#{max})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t\tif Meteor.isServer\n\t\t\t\tif field.autoform\n\t\t\t\t\t_type = field.autoform.type\n\t\t\t\t\tif _type && _.isFunction(_type) && _type != Object && _type != String && _type != Number && _type != Boolean && !_.isArray(_type)\n\t\t\t\t\t\tfield.autoform._type = _type.toString()\n\t\t\telse\n\t\t\t\tif field.autoform\n\t\t\t\t\t_type = field.autoform._type\n\t\t\t\t\tif _type && _.isString(_type)\n\t\t\t\t\t\ttry\n\t\t\t\t\t\t\tfield.autoform.type = Creator.eval(\"(#{_type})\")\n\t\t\t\t\t\tcatch error\n\t\t\t\t\t\t\tconsole.error \"convert field -> type error\", field, error\n\n\t\t\tif Meteor.isServer\n\n\t\t\t\toptionsFunction = field.optionsFunction\n\t\t\t\treference_to = field.reference_to\n\t\t\t\tcreateFunction = field.createFunction\n\t\t\t\tbeforeOpenFunction = field.beforeOpenFunction\n\t\t\t\tfiltersFunction = field.filtersFunction\n\n\t\t\t\tif optionsFunction && _.isFunction(optionsFunction)\n\t\t\t\t\tfield._optionsFunction = optionsFunction.toString()\n\n\t\t\t\tif reference_to && _.isFunction(reference_to)\n\t\t\t\t\tfield._reference_to = reference_to.toString()\n\n\t\t\t\tif createFunction && _.isFunction(createFunction)\n\t\t\t\t\tfield._createFunction = createFunction.toString()\n\t\t\t\tif beforeOpenFunction && _.isFunction(beforeOpenFunction)\n\t\t\t\t\tfield._beforeOpenFunction = beforeOpenFunction.toString()\n\n\t\t\t\tif filtersFunction && _.isFunction(filtersFunction)\n\t\t\t\t\tfield._filtersFunction = filtersFunction.toString()\n\t\t\telse\n\n\t\t\t\toptionsFunction = field._optionsFunction || field.optionsFunction\n\t\t\t\treference_to = field._reference_to\n\t\t\t\tcreateFunction = field._createFunction\n\t\t\t\tbeforeOpenFunction = field._beforeOpenFunction\n\t\t\t\tfiltersFunction = field._filtersFunction || field.filtersFunction\n\n\t\t\t\tif optionsFunction && _.isString(optionsFunction)\n\t\t\t\t\tfield.optionsFunction = Creator.eval(\"(#{optionsFunction})\")\n\n\t\t\t\tif reference_to && _.isString(reference_to)\n\t\t\t\t\tfield.reference_to = Creator.eval(\"(#{reference_to})\")\n\n\t\t\t\tif createFunction && _.isString(createFunction)\n\t\t\t\t\tfield.createFunction = Creator.eval(\"(#{createFunction})\")\n\n\t\t\t\tif beforeOpenFunction && _.isString(beforeOpenFunction)\n\t\t\t\t\tfield.beforeOpenFunction = Creator.eval(\"(#{beforeOpenFunction})\")\n\n\t\t\t\tif filtersFunction && _.isString(filtersFunction)\n\t\t\t\t\tfield.filtersFunction = Creator.eval(\"(#{filtersFunction})\")\n\n\t\t\tif Meteor.isServer\n\t\t\t\tdefaultValue = field.defaultValue\n\t\t\t\tif defaultValue && _.isFunction(defaultValue)\n\t\t\t\t\tfield._defaultValue = field.defaultValue.toString()\n\t\t\telse\n\t\t\t\tdefaultValue = field._defaultValue\n\n\t\t\t\tif !defaultValue && _.isString(field.defaultValue) && field.defaultValue.startsWith(\"function\")\n\t\t\t\t\tdefaultValue = field.defaultValue\n\n\t\t\t\tif defaultValue && _.isString(defaultValue)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.defaultValue = Creator.eval(\"(#{defaultValue})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\t\t\t\n\t\t\tif Meteor.isServer\n\t\t\t\tis_company_limited = field.is_company_limited\n\t\t\t\tif is_company_limited && _.isFunction(is_company_limited)\n\t\t\t\t\tfield._is_company_limited = field.is_company_limited.toString()\n\t\t\telse\n\t\t\t\tis_company_limited = field._is_company_limited\n\t\t\t\tif is_company_limited && _.isString(is_company_limited)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.is_company_limited = Creator.eval(\"(#{is_company_limited})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t_.forEach object.list_views, (list_view, key) ->\n\t\t\t###\n\t\t\t视图过虑器需要支持function，后台转成字符串，前台eval成函数\n\t\t\t让过虑器支持两种function方式：\n\t\t\t1. 整个filters为function:\n\t\t\t如：\n\t\t\tfilters: ()->\n\t\t\t\treturn [[[\"object_name\",\"=\",\"project_issues\"],'or',[\"object_name\",\"=\",\"tasks\"]]]\n\t\t\t2. filters内的filter.value为function\n\t\t\t如：\n\t\t\tfilters: [[\"object_name\", \"=\", ()->\n\t\t\t\treturn \"project_issues\"\n\t\t\t]]\n\t\t\t或\n\t\t\tfilters: [{\n\t\t\t\t\"field\": \"object_name\"\n\t\t\t\t\"operation\": \"=\"\n\t\t\t\t\"value\": ()->\n\t\t\t\t\treturn \"project_issues\"\n\t\t\t}]\n\t\t\t###\n\t\t\tif _.isFunction(list_view.filters)\n\t\t\t\tif Meteor.isServer\n\t\t\t\t\tlist_view._filters = list_view.filters.toString()\n\t\t\telse if _.isString(list_view._filters)\n\t\t\t\tif Meteor.isClient\n\t\t\t\t\tlist_view.filters = Creator.eval(\"(#{list_view._filters})\")\n\t\t\telse\n\t\t\t\t_.forEach list_view.filters, (filter, _index)->\n\t\t\t\t\tif _.isArray(filter)\n\t\t\t\t\t\tif Meteor.isServer\n\t\t\t\t\t\t\tif filter.length == 3 and _.isFunction(filter[2])\n\t\t\t\t\t\t\t\tfilter[2] = filter[2].toString()\n\t\t\t\t\t\t\t\tfilter[3] = \"FUNCTION\"\n\t\t\t\t\t\t\telse if filter.length == 3 and _.isDate(filter[2])\n\t\t\t\t\t\t\t\t# 如果是Date类型，则filter[2]值到前端会自动转成字符串，格式：\"2018-03-29T03:43:21.787Z\"\n\t\t\t\t\t\t\t\t# 包括grid列表请求的接口在内的所有OData接口，Date类型字段都会以上述格式返回\n\t\t\t\t\t\t\t\tfilter[3] = \"DATE\"\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tif filter.length == 4 and _.isString(filter[2]) and filter[3] == \"FUNCTION\"\n\t\t\t\t\t\t\t\tfilter[2] = Creator.eval(\"(#{filter[2]})\")\n\t\t\t\t\t\t\t\tfilter.pop()\n\t\t\t\t\t\t\tif filter.length == 4 and _.isString(filter[2]) and filter[3] == \"DATE\"\n\t\t\t\t\t\t\t\tfilter[2] = new Date(filter[2])\n\t\t\t\t\t\t\t\tfilter.pop()\n\t\t\t\t\telse if _.isObject(filter)\n\t\t\t\t\t\tif Meteor.isServer\n\t\t\t\t\t\t\tif _.isFunction(filter?.value)\n\t\t\t\t\t\t\t\tfilter._value = filter.value.toString()\n\t\t\t\t\t\t\telse if _.isDate(filter?.value)\n\t\t\t\t\t\t\t\tfilter._is_date = true\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tif _.isString(filter?._value)\n\t\t\t\t\t\t\t\tfilter.value = Creator.eval(\"(#{filter._value})\")\n\t\t\t\t\t\t\telse if filter._is_date == true\n\t\t\t\t\t\t\t\tfilter.value = new Date(filter.value)\n\n\t\tif Meteor.isServer\n\t\t\tif object.form && !_.isString(object.form)\n\t\t\t\tobject.form = JSON.stringify object.form, (key, val)->\n\t\t\t\t\tif _.isFunction(val)\n\t\t\t\t\t\treturn val + '';\n\t\t\t\t\telse\n\t\t\t\t\t\treturn val;\n\t\telse if Meteor.isClient\n\t\t\tif object.form\n\t\t\t\tobject.form = JSON.parse object.form, (key, val)->\n\t\t\t\t\tif _.isString(val) && val.startsWith('function')\n\t\t\t\t\t\treturn Creator.eval(\"(#{val})\")\n\t\t\t\t\telse\n\t\t\t\t\t\treturn val;\n\n\t\tif Meteor.isClient\n\t\t\t_.forEach object.related_lists, (relatedObjInfo)->\n\t\t\t\tif _.isObject(relatedObjInfo)\n\t\t\t\t\t_.forEach relatedObjInfo, (val, key)->\n\t\t\t\t\t\tif key == 'filters' && _.isString(val)\n\t\t\t\t\t\t\ttry\n\t\t\t\t\t\t\t\trelatedObjInfo[key] = Creator.eval(\"(#{val})\")\n\t\t\t\t\t\t\tcatch error\n\t\t\t\t\t\t\t\tconsole.error \"filters_code\", val\n\t\telse\n\t\t\t_.forEach object.related_lists, (relatedObjInfo)->\n\t\t\t\tif _.isObject(relatedObjInfo)\n\t\t\t\t\t_.forEach relatedObjInfo, (val, key)->\n\t\t\t\t\t\tif key == 'filters' && _.isFunction(val)\n\t\t\t\t\t\t\trelatedObjInfo[key] = val.toString()\n\n\t\tif Meteor.isClient\n\t\t\t_.forEach object.relatedList, (relatedObjInfo)->\n\t\t\t\tif _.isObject(relatedObjInfo)\n\t\t\t\t\t_.forEach relatedObjInfo, (val, key)->\n\t\t\t\t\t\tif key == 'filters' && _.isString(val)\n\t\t\t\t\t\t\ttry\n\t\t\t\t\t\t\t\trelatedObjInfo[key] = Creator.eval(\"(#{val})\")\n\t\t\t\t\t\t\tcatch error\n\t\t\t\t\t\t\t\tconsole.error \"filters_code\", val\n\t\telse\n\t\t\t_.forEach object.relatedList, (relatedObjInfo)->\n\t\t\t\tif _.isObject(relatedObjInfo)\n\t\t\t\t\t_.forEach relatedObjInfo, (val, key)->\n\t\t\t\t\t\tif key == 'filters' && _.isFunction(val)\n\t\t\t\t\t\t\trelatedObjInfo[key] = val.toString()\n\n\t\treturn object\n\n\n","var convertField, getOption;\n\ngetOption = function(option) {\n  var foo;\n  foo = option.split(\":\");\n  if (foo.length > 2) {\n    return {\n      label: foo[0],\n      value: foo[1],\n      color: foo[2]\n    };\n  } else if (foo.length > 1) {\n    return {\n      label: foo[0],\n      value: foo[1]\n    };\n  } else {\n    return {\n      label: foo[0],\n      value: foo[0]\n    };\n  }\n};\n\nconvertField = function(object_name, field_name, field, spaceId) {\n  var allOptions, code, options, picklist, picklistOptions, ref;\n  if (Meteor.isServer && spaceId && field.type === 'select') {\n    code = field.picklist || (object_name + \".\" + field_name);\n    if (code) {\n      picklist = Creator.getPicklist(code, spaceId);\n      if (picklist) {\n        options = [];\n        allOptions = [];\n        picklistOptions = Creator.getPickListOptions(picklist);\n        picklistOptions = (ref = _.sortBy(picklistOptions, 'sort_no')) != null ? ref.reverse() : void 0;\n        _.each(picklistOptions, function(item) {\n          var label, value;\n          label = item.name;\n          value = item.value || item.name;\n          allOptions.push({\n            label: label,\n            value: value,\n            enable: item.enable,\n            color: item.color\n          });\n          if (item.enable) {\n            options.push({\n              label: label,\n              value: value,\n              color: item.color\n            });\n          }\n          if (item[\"default\"]) {\n            return field.defaultValue = value;\n          }\n        });\n        if (options.length > 0) {\n          field.options = options;\n        }\n        if (allOptions.length > 0) {\n          field.allOptions = allOptions;\n        }\n      }\n    }\n  }\n  return field;\n};\n\nCreator.convertObject = function(object, spaceId) {\n  if (!object) {\n    return;\n  }\n  _.forEach(object.triggers, function(trigger, key) {\n    var _todo, _todo_from_code, _todo_from_db;\n    if ((Meteor.isServer && trigger.on === \"server\") || (Meteor.isClient && trigger.on === \"client\")) {\n      _todo_from_code = trigger != null ? trigger._todo : void 0;\n      _todo_from_db = trigger.todo;\n      if (_todo_from_code && _.isString(_todo_from_code)) {\n        trigger.todo = Creator[\"eval\"](\"(\" + _todo_from_code + \")\");\n      }\n      if (_todo_from_db && _.isString(_todo_from_db)) {\n        if (_todo_from_db.startsWith(\"function\")) {\n          trigger.todo = Creator[\"eval\"](\"(\" + _todo_from_db + \")\");\n        } else {\n          trigger.todo = Creator[\"eval\"](\"(function(userId, doc, fieldNames, modifier, options){\" + _todo_from_db + \"})\");\n        }\n      }\n    }\n    if (Meteor.isServer && trigger.on === \"client\") {\n      _todo = trigger.todo;\n      if (_todo && _.isFunction(_todo)) {\n        return trigger._todo = _todo.toString();\n      }\n    }\n  });\n  if (Meteor.isClient) {\n    _.forEach(object.fields, function(field, key) {\n      var systemBaseFields;\n      if (field.omit) {\n        field.hidden = true;\n      }\n      if (field.required && field.readonly) {\n        field.readonly = false;\n      }\n      systemBaseFields = Creator.getSystemBaseFields();\n      if (systemBaseFields.indexOf(key) > -1) {\n        return field.readonly = true;\n      }\n    });\n    _.forEach(object.actions, function(action, key) {\n      var _todo_from_code, _todo_from_db, _visible, error;\n      _todo_from_code = action != null ? action._todo : void 0;\n      _todo_from_db = action != null ? action.todo : void 0;\n      if (_todo_from_code && _.isString(_todo_from_code)) {\n        try {\n          action.todo = Creator[\"eval\"](\"(\" + _todo_from_code + \")\");\n        } catch (error1) {\n          error = error1;\n          console.error(\"todo_from_code\", _todo_from_code);\n        }\n      }\n      if (_todo_from_db && _.isString(_todo_from_db)) {\n        try {\n          if (_todo_from_db.startsWith(\"function\")) {\n            action.todo = Creator[\"eval\"](\"(\" + _todo_from_db + \")\");\n          } else {\n            if (_.isFunction(Creator.actionsByName[_todo_from_db])) {\n              action.todo = _todo_from_db;\n            } else {\n              action.todo = Creator[\"eval\"](\"(function(){\" + _todo_from_db + \"})\");\n            }\n          }\n        } catch (error1) {\n          error = error1;\n          console.error(\"todo_from_db\", _todo_from_db, error);\n        }\n      }\n      _visible = action != null ? action._visible : void 0;\n      if (_visible) {\n        try {\n          if (_.isString(_visible)) {\n            _visible = _visible.trim();\n          }\n          if (Steedos.isExpression(_visible)) {\n            return action.visible = function(object_name, record_id, record_permissions, record) {\n              var globalData;\n              globalData = Object.assign({}, Creator.USER_CONTEXT, {\n                now: new Date()\n              });\n              return Steedos.parseSingleExpression(_visible, record, \"#\", globalData);\n            };\n          } else {\n            return action.visible = Creator[\"eval\"](\"(\" + _visible + \")\");\n          }\n        } catch (error1) {\n          error = error1;\n          return console.error(\"action.visible to function error: \", error, _visible);\n        }\n      }\n    });\n  } else {\n    _.forEach(object.actions, function(action, key) {\n      var _todo, _visible;\n      _todo = action != null ? action.todo : void 0;\n      if (_todo && _.isFunction(_todo)) {\n        action._todo = _todo.toString();\n      }\n      _visible = action != null ? action.visible : void 0;\n      if (_visible && _.isFunction(_visible)) {\n        return action._visible = _visible.toString();\n      }\n    });\n  }\n  _.forEach(object.fields, function(field, key) {\n    var _options, _type, beforeOpenFunction, createFunction, defaultValue, error, filtersFunction, is_company_limited, max, min, options, optionsFunction, reference_to, regEx;\n    field = convertField(object.name, key, field, spaceId);\n    if (field.options && _.isString(field.options)) {\n      try {\n        _options = [];\n        _.forEach(field.options.split(\"\\n\"), function(option) {\n          var options;\n          if (option.indexOf(\",\")) {\n            options = option.split(\",\");\n            return _.forEach(options, function(_option) {\n              return _options.push(getOption(_option));\n            });\n          } else {\n            return _options.push(getOption(option));\n          }\n        });\n        field.options = _options;\n      } catch (error1) {\n        error = error1;\n        console.error(\"Creator.convertFieldsOptions\", field.options, error);\n      }\n    } else if (field.options && _.isArray(field.options)) {\n      try {\n        _options = [];\n        _.forEach(field.options, function(option) {\n          if (_.isString(option)) {\n            return _options.push(getOption(option));\n          } else {\n            return _options.push(option);\n          }\n        });\n        field.options = _options;\n      } catch (error1) {\n        error = error1;\n        console.error(\"Creator.convertFieldsOptions\", field.options, error);\n      }\n    } else if (field.options && !_.isFunction(field.options) && !_.isArray(field.options) && _.isObject(field.options)) {\n      _options = [];\n      _.each(field.options, function(v, k) {\n        return _options.push({\n          label: v,\n          value: k\n        });\n      });\n      field.options = _options;\n    }\n    if (Meteor.isServer) {\n      options = field.options;\n      if (options && _.isFunction(options)) {\n        field._options = field.options.toString();\n      }\n    } else {\n      options = field._options;\n      if (options && _.isString(options)) {\n        try {\n          field.options = Creator[\"eval\"](\"(\" + options + \")\");\n        } catch (error1) {\n          error = error1;\n          console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n        }\n      }\n    }\n    if (Meteor.isServer) {\n      regEx = field.regEx;\n      if (regEx) {\n        field._regEx = field.regEx.toString();\n      }\n    } else {\n      regEx = field._regEx;\n      if (regEx) {\n        try {\n          field.regEx = Creator[\"eval\"](\"(\" + regEx + \")\");\n        } catch (error1) {\n          error = error1;\n          console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n        }\n      }\n    }\n    if (Meteor.isServer) {\n      min = field.min;\n      if (_.isFunction(min)) {\n        field._min = min.toString();\n      }\n    } else {\n      min = field._min;\n      if (_.isString(min)) {\n        try {\n          field.min = Creator[\"eval\"](\"(\" + min + \")\");\n        } catch (error1) {\n          error = error1;\n          console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n        }\n      }\n    }\n    if (Meteor.isServer) {\n      max = field.max;\n      if (_.isFunction(max)) {\n        field._max = max.toString();\n      }\n    } else {\n      max = field._max;\n      if (_.isString(max)) {\n        try {\n          field.max = Creator[\"eval\"](\"(\" + max + \")\");\n        } catch (error1) {\n          error = error1;\n          console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n        }\n      }\n    }\n    if (Meteor.isServer) {\n      if (field.autoform) {\n        _type = field.autoform.type;\n        if (_type && _.isFunction(_type) && _type !== Object && _type !== String && _type !== Number && _type !== Boolean && !_.isArray(_type)) {\n          field.autoform._type = _type.toString();\n        }\n      }\n    } else {\n      if (field.autoform) {\n        _type = field.autoform._type;\n        if (_type && _.isString(_type)) {\n          try {\n            field.autoform.type = Creator[\"eval\"](\"(\" + _type + \")\");\n          } catch (error1) {\n            error = error1;\n            console.error(\"convert field -> type error\", field, error);\n          }\n        }\n      }\n    }\n    if (Meteor.isServer) {\n      optionsFunction = field.optionsFunction;\n      reference_to = field.reference_to;\n      createFunction = field.createFunction;\n      beforeOpenFunction = field.beforeOpenFunction;\n      filtersFunction = field.filtersFunction;\n      if (optionsFunction && _.isFunction(optionsFunction)) {\n        field._optionsFunction = optionsFunction.toString();\n      }\n      if (reference_to && _.isFunction(reference_to)) {\n        field._reference_to = reference_to.toString();\n      }\n      if (createFunction && _.isFunction(createFunction)) {\n        field._createFunction = createFunction.toString();\n      }\n      if (beforeOpenFunction && _.isFunction(beforeOpenFunction)) {\n        field._beforeOpenFunction = beforeOpenFunction.toString();\n      }\n      if (filtersFunction && _.isFunction(filtersFunction)) {\n        field._filtersFunction = filtersFunction.toString();\n      }\n    } else {\n      optionsFunction = field._optionsFunction || field.optionsFunction;\n      reference_to = field._reference_to;\n      createFunction = field._createFunction;\n      beforeOpenFunction = field._beforeOpenFunction;\n      filtersFunction = field._filtersFunction || field.filtersFunction;\n      if (optionsFunction && _.isString(optionsFunction)) {\n        field.optionsFunction = Creator[\"eval\"](\"(\" + optionsFunction + \")\");\n      }\n      if (reference_to && _.isString(reference_to)) {\n        field.reference_to = Creator[\"eval\"](\"(\" + reference_to + \")\");\n      }\n      if (createFunction && _.isString(createFunction)) {\n        field.createFunction = Creator[\"eval\"](\"(\" + createFunction + \")\");\n      }\n      if (beforeOpenFunction && _.isString(beforeOpenFunction)) {\n        field.beforeOpenFunction = Creator[\"eval\"](\"(\" + beforeOpenFunction + \")\");\n      }\n      if (filtersFunction && _.isString(filtersFunction)) {\n        field.filtersFunction = Creator[\"eval\"](\"(\" + filtersFunction + \")\");\n      }\n    }\n    if (Meteor.isServer) {\n      defaultValue = field.defaultValue;\n      if (defaultValue && _.isFunction(defaultValue)) {\n        field._defaultValue = field.defaultValue.toString();\n      }\n    } else {\n      defaultValue = field._defaultValue;\n      if (!defaultValue && _.isString(field.defaultValue) && field.defaultValue.startsWith(\"function\")) {\n        defaultValue = field.defaultValue;\n      }\n      if (defaultValue && _.isString(defaultValue)) {\n        try {\n          field.defaultValue = Creator[\"eval\"](\"(\" + defaultValue + \")\");\n        } catch (error1) {\n          error = error1;\n          console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n        }\n      }\n    }\n    if (Meteor.isServer) {\n      is_company_limited = field.is_company_limited;\n      if (is_company_limited && _.isFunction(is_company_limited)) {\n        return field._is_company_limited = field.is_company_limited.toString();\n      }\n    } else {\n      is_company_limited = field._is_company_limited;\n      if (is_company_limited && _.isString(is_company_limited)) {\n        try {\n          return field.is_company_limited = Creator[\"eval\"](\"(\" + is_company_limited + \")\");\n        } catch (error1) {\n          error = error1;\n          return console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n        }\n      }\n    }\n  });\n  _.forEach(object.list_views, function(list_view, key) {\n\n    /*\n    \t\t\t视图过虑器需要支持function，后台转成字符串，前台eval成函数\n    \t\t\t让过虑器支持两种function方式：\n    \t\t\t1. 整个filters为function:\n    \t\t\t如：\n    \t\t\tfilters: ()->\n    \t\t\t\treturn [[[\"object_name\",\"=\",\"project_issues\"],'or',[\"object_name\",\"=\",\"tasks\"]]]\n    \t\t\t2. filters内的filter.value为function\n    \t\t\t如：\n    \t\t\tfilters: [[\"object_name\", \"=\", ()->\n    \t\t\t\treturn \"project_issues\"\n    \t\t\t]]\n    \t\t\t或\n    \t\t\tfilters: [{\n    \t\t\t\t\"field\": \"object_name\"\n    \t\t\t\t\"operation\": \"=\"\n    \t\t\t\t\"value\": ()->\n    \t\t\t\t\treturn \"project_issues\"\n    \t\t\t}]\n     */\n    if (_.isFunction(list_view.filters)) {\n      if (Meteor.isServer) {\n        return list_view._filters = list_view.filters.toString();\n      }\n    } else if (_.isString(list_view._filters)) {\n      if (Meteor.isClient) {\n        return list_view.filters = Creator[\"eval\"](\"(\" + list_view._filters + \")\");\n      }\n    } else {\n      return _.forEach(list_view.filters, function(filter, _index) {\n        if (_.isArray(filter)) {\n          if (Meteor.isServer) {\n            if (filter.length === 3 && _.isFunction(filter[2])) {\n              filter[2] = filter[2].toString();\n              return filter[3] = \"FUNCTION\";\n            } else if (filter.length === 3 && _.isDate(filter[2])) {\n              return filter[3] = \"DATE\";\n            }\n          } else {\n            if (filter.length === 4 && _.isString(filter[2]) && filter[3] === \"FUNCTION\") {\n              filter[2] = Creator[\"eval\"](\"(\" + filter[2] + \")\");\n              filter.pop();\n            }\n            if (filter.length === 4 && _.isString(filter[2]) && filter[3] === \"DATE\") {\n              filter[2] = new Date(filter[2]);\n              return filter.pop();\n            }\n          }\n        } else if (_.isObject(filter)) {\n          if (Meteor.isServer) {\n            if (_.isFunction(filter != null ? filter.value : void 0)) {\n              return filter._value = filter.value.toString();\n            } else if (_.isDate(filter != null ? filter.value : void 0)) {\n              return filter._is_date = true;\n            }\n          } else {\n            if (_.isString(filter != null ? filter._value : void 0)) {\n              return filter.value = Creator[\"eval\"](\"(\" + filter._value + \")\");\n            } else if (filter._is_date === true) {\n              return filter.value = new Date(filter.value);\n            }\n          }\n        }\n      });\n    }\n  });\n  if (Meteor.isServer) {\n    if (object.form && !_.isString(object.form)) {\n      object.form = JSON.stringify(object.form, function(key, val) {\n        if (_.isFunction(val)) {\n          return val + '';\n        } else {\n          return val;\n        }\n      });\n    }\n  } else if (Meteor.isClient) {\n    if (object.form) {\n      object.form = JSON.parse(object.form, function(key, val) {\n        if (_.isString(val) && val.startsWith('function')) {\n          return Creator[\"eval\"](\"(\" + val + \")\");\n        } else {\n          return val;\n        }\n      });\n    }\n  }\n  if (Meteor.isClient) {\n    _.forEach(object.related_lists, function(relatedObjInfo) {\n      if (_.isObject(relatedObjInfo)) {\n        return _.forEach(relatedObjInfo, function(val, key) {\n          var error;\n          if (key === 'filters' && _.isString(val)) {\n            try {\n              return relatedObjInfo[key] = Creator[\"eval\"](\"(\" + val + \")\");\n            } catch (error1) {\n              error = error1;\n              return console.error(\"filters_code\", val);\n            }\n          }\n        });\n      }\n    });\n  } else {\n    _.forEach(object.related_lists, function(relatedObjInfo) {\n      if (_.isObject(relatedObjInfo)) {\n        return _.forEach(relatedObjInfo, function(val, key) {\n          if (key === 'filters' && _.isFunction(val)) {\n            return relatedObjInfo[key] = val.toString();\n          }\n        });\n      }\n    });\n  }\n  if (Meteor.isClient) {\n    _.forEach(object.relatedList, function(relatedObjInfo) {\n      if (_.isObject(relatedObjInfo)) {\n        return _.forEach(relatedObjInfo, function(val, key) {\n          var error;\n          if (key === 'filters' && _.isString(val)) {\n            try {\n              return relatedObjInfo[key] = Creator[\"eval\"](\"(\" + val + \")\");\n            } catch (error1) {\n              error = error1;\n              return console.error(\"filters_code\", val);\n            }\n          }\n        });\n      }\n    });\n  } else {\n    _.forEach(object.relatedList, function(relatedObjInfo) {\n      if (_.isObject(relatedObjInfo)) {\n        return _.forEach(relatedObjInfo, function(val, key) {\n          if (key === 'filters' && _.isFunction(val)) {\n            return relatedObjInfo[key] = val.toString();\n          }\n        });\n      }\n    });\n  }\n  return object;\n};\n","Creator.Formular = {}\n\nCreator.Formular.PREFIX = \"_VALUES\"\n\nCreator.Formular._prependPrefixForFormula = (prefix,fieldVariable)->\n\treg = /(\\{[^{}]*\\})/g;\n\n\trev = fieldVariable.replace reg, (m, $1)->\n\t\treturn prefix + $1.replace(/\\{\\s*/,\"[\\\"\").replace(/\\s*\\}/,\"\\\"]\").replace(/\\s*\\.\\s*/g,\"\\\"][\\\"\");\n\n\treturn rev\n\nCreator.Formular.checkFormula = (formula_str)->\n\tif _.isString(formula_str) && formula_str.indexOf(\"{\") > -1 && formula_str.indexOf(\"}\") > -1\n\t\treturn true\n\treturn false\n\nCreator.Formular.run = (formula_str, _CONTEXT, options)->\n\tif formula_str && _.isString(formula_str)\n\n\t\tif !_.isBoolean(options?.extend)\n\t\t\textend = true\n\n\t\t_VALUES = {}\n\t\t_VALUES = _.extend(_VALUES, _CONTEXT)\n\t\tif extend\n\t\t\t_VALUES = _.extend(_VALUES, Creator.getUserContext(options?.userId, options?.spaceId))\n\t\tformula_str = Creator.Formular._prependPrefixForFormula(\"this\", formula_str)\n\n\t\ttry\n\t\t\tdata = Creator.evalInContext(formula_str, _VALUES)   # 此处不能用window.eval ，会导致变量作用域异常\n\t\t\treturn data\n\t\tcatch e\n\t\t\tconsole.error(\"Creator.Formular.run: #{formula_str}\", e)\n\t\t\tif Meteor.isClient\n\t\t\t\ttoastr?.error(\"公式执行出错了，请检查公式配置是否正确！\")\n\t\t\tthrow new Meteor.Error 500, \"Creator.Formular.run: #{formula_str}#{e}\"\n\n\treturn formula_str\n","Creator.Formular = {};\n\nCreator.Formular.PREFIX = \"_VALUES\";\n\nCreator.Formular._prependPrefixForFormula = function(prefix, fieldVariable) {\n  var reg, rev;\n  reg = /(\\{[^{}]*\\})/g;\n  rev = fieldVariable.replace(reg, function(m, $1) {\n    return prefix + $1.replace(/\\{\\s*/, \"[\\\"\").replace(/\\s*\\}/, \"\\\"]\").replace(/\\s*\\.\\s*/g, \"\\\"][\\\"\");\n  });\n  return rev;\n};\n\nCreator.Formular.checkFormula = function(formula_str) {\n  if (_.isString(formula_str) && formula_str.indexOf(\"{\") > -1 && formula_str.indexOf(\"}\") > -1) {\n    return true;\n  }\n  return false;\n};\n\nCreator.Formular.run = function(formula_str, _CONTEXT, options) {\n  var _VALUES, data, e, extend;\n  if (formula_str && _.isString(formula_str)) {\n    if (!_.isBoolean(options != null ? options.extend : void 0)) {\n      extend = true;\n    }\n    _VALUES = {};\n    _VALUES = _.extend(_VALUES, _CONTEXT);\n    if (extend) {\n      _VALUES = _.extend(_VALUES, Creator.getUserContext(options != null ? options.userId : void 0, options != null ? options.spaceId : void 0));\n    }\n    formula_str = Creator.Formular._prependPrefixForFormula(\"this\", formula_str);\n    try {\n      data = Creator.evalInContext(formula_str, _VALUES);\n      return data;\n    } catch (error) {\n      e = error;\n      console.error(\"Creator.Formular.run: \" + formula_str, e);\n      if (Meteor.isClient) {\n        if (typeof toastr !== \"undefined\" && toastr !== null) {\n          toastr.error(\"公式执行出错了，请检查公式配置是否正确！\");\n        }\n      }\n      throw new Meteor.Error(500, \"Creator.Formular.run: \" + formula_str + e);\n    }\n  }\n  return formula_str;\n};\n","clone = require('clone');\nCreator.objectsByName = {}   # 此对象只能在确保所有Object初始化完成后调用， 否则获取到的object不全\n\nCreator.formatObjectName = (object_name)->\n\tif object_name.startsWith('cfs.files.')\n\t\tobject_name = object_name.replace(new RegExp('\\\\.', 'g'), '_')\n\treturn object_name\n\nCreator.Object = (options)->\n\t_baseObject = Creator.baseObject\n\tif Meteor.isClient\n\t\t_baseObject = {actions: Creator.baseObject.actions , fields: {}, triggers: {}, permission_set: {}}\n\tself = this\n\tif (!options.name)\n\t\tconsole.error(options)\n\t\tthrow new Error('Creator.Object options must specify name');\n\n\tself._id = options._id || options.name\n\tself.space = options.space\n\tself.name = options.name\n\tself.label = options.label\n\tself.icon = options.icon\n\tself.description = options.description\n\tself.is_view = options.is_view\n\tself.form = options.form\n\tself.relatedList = options.relatedList\n\tself.related_lists = options.related_lists\n\tself.hasImportTemplates = options.hasImportTemplates\n\tself.version = options.version || 1.0\n\tif !_.isBoolean(options.is_enable)  || options.is_enable == true\n\t\tself.is_enable = true\n\telse\n\t\tself.is_enable = false\n\tif Meteor.isClient\n\t\tif _.has(options, 'allow_customActions')\n\t\t\tself.allow_customActions = options.allow_customActions\n\t\tif _.has(options, 'exclude_actions')\n\t\t\tself.exclude_actions = options.exclude_actions\n\t\tif _.has(options, 'allow_relatedList')\n\t\t\tself.allow_relatedList = options.allow_relatedList\n\tself.enable_search = options.enable_search\n\tself.enable_files = options.enable_files\n\tself.enable_tasks = options.enable_tasks\n\tself.enable_notes = options.enable_notes\n\tself.enable_audit = options.enable_audit\n\tself.enable_events = options.enable_events\n\tif options.paging\n\t\tself.paging = options.paging\n\tself.hidden = options.hidden\n\tself.enable_api = (options.enable_api == undefined) or options.enable_api\n\tself.custom = options.custom\n\tself.enable_share = options.enable_share\n\tself.enable_instances = options.enable_instances\n\tself.enable_process = options.enable_process\n\tif Meteor.isClient\n\t\tif Creator.isCloudAdminSpace(Session.get(\"spaceId\"))\n\t\t\tself.enable_tree = false\n\t\telse\n\t\t\tself.enable_tree = options.enable_tree\n\t\t\tself.sidebar = _.clone(options.sidebar)\n\telse\n\t\tself.sidebar = _.clone(options.sidebar)\n\t\tself.enable_tree = options.enable_tree\n\tself.open_window = options.open_window\n\tself.filter_company = options.filter_company\n\tself.calendar = _.clone(options.calendar)\n\tself.enable_chatter = options.enable_chatter\n\tself.enable_trash = options.enable_trash\n\tself.enable_space_global = options.enable_space_global\n\tself.enable_approvals = options.enable_approvals\n\tself.enable_follow = options.enable_follow\n\tself.enable_workflow = options.enable_workflow\n\tself.enable_inline_edit = options.enable_inline_edit\n\tself.details = options.details\n\tself.masters = options.masters\n\tself.lookup_details = options.lookup_details\n\tif _.has(options, 'in_development')\n\t\tself.in_development = options.in_development\n\tself.idFieldName = '_id'\n\tif options.database_name\n\t\tself.database_name = options.database_name\n\tif (!options.fields)\n\t\tconsole.error(options)\n\t\tthrow new Error('Creator.Object options must specify fields');\n\n\tself.fields = clone(options.fields)\n\n\t_.each self.fields, (field, field_name)->\n\t\tif field.is_name\n\t\t\tself.NAME_FIELD_KEY = field_name\n\t\telse if field_name == 'name' && !self.NAME_FIELD_KEY\n\t\t\tself.NAME_FIELD_KEY = field_name\n\t\tif field.primary\n\t\t\tself.idFieldName = field_name\n\t\tif Meteor.isClient\n\t\t\tif Creator.isCloudAdminSpace(Session.get(\"spaceId\"))\n\t\t\t\tif field_name == 'space'\n\t\t\t\t\tfield.filterable = true\n\t\t\t\t\tfield.hidden = false\n\n\tif !options.database_name || options.database_name == 'meteor-mongo'\n\t\t_.each _baseObject.fields, (field, field_name)->\n\t\t\tif !self.fields[field_name]\n\t\t\t\tself.fields[field_name] = {}\n\t\t\tself.fields[field_name] = _.extend(_.clone(field), self.fields[field_name])\n\n\t_.each self.fields, (field, field_name)->\n\t\tif field.type == 'autonumber'\n\t\t\tfield.readonly = true\n\t\telse if field.type == 'formula'\n\t\t\tfield.readonly = true\n\t\telse if field.type == 'summary'\n\t\t\tfield.readonly = true\n\n\tself.list_views = {}\n\tdefaultView = Creator.getObjectDefaultView(self.name)\n\t_.each options.list_views, (item, item_name)->\n\t\toitem = Creator.convertListView(defaultView, item, item_name)\n\t\tself.list_views[item_name] = oitem\n\n\tself.triggers = _.clone(_baseObject.triggers)\n\t_.each options.triggers, (item, item_name)->\n\t\tif !self.triggers[item_name]\n\t\t\tself.triggers[item_name] = {}\n\t\tself.triggers[item_name].name = item_name\n\t\tself.triggers[item_name] = _.extend(_.clone(self.triggers[item_name]), item)\n\n\tself.actions = _.clone(_baseObject.actions)\n\t_.each options.actions, (item, item_name)->\n\t\tif !self.actions[item_name]\n\t\t\tself.actions[item_name] = {}\n\t\tcopyItem = _.clone(self.actions[item_name])\n\t\tdelete self.actions[item_name] #先删除相关属性再重建才能保证后续重复定义的属性顺序生效\n\t\tself.actions[item_name] = _.extend(copyItem, item)\n\t\tself.actions[item_name].object_name = self.name\n\n\t_.each self.actions, (item, item_name)->\n\t\titem.name = item_name\n\n\tself.related_objects = Creator.getObjectRelateds(self.name)\n\n\t# 让所有object默认有所有list_views/actions/related_objects/readable_fields/editable_fields完整权限，该权限可能被数据库中设置的admin/user权限覆盖\n\tself.permission_set = _.clone(_baseObject.permission_set)\n\t# defaultListViews = _.keys(self.list_views)\n\t# defaultActions = _.keys(self.actions)\n\t# defaultRelatedObjects = _.pluck(self.related_objects,\"object_name\")\n\t# defaultReadableFields = []\n\t# defaultEditableFields = []\n\t# _.each self.fields, (field, field_name)->\n\t# \tif !(field.hidden)    #231 omit字段支持在非编辑页面查看, 因此删除了此处对omit的判断\n\t# \t\tdefaultReadableFields.push field_name\n\t# \t\tif !field.readonly\n\t# \t\t\tdefaultEditableFields.push field_name\n\n\t# _.each self.permission_set, (item, item_name)->\n\t# \tif item_name == \"none\"\n\t# \t\treturn\n\t# \tif self.list_views\n\t# \t\tself.permission_set[item_name].list_views = defaultListViews\n\t# \tif self.actions\n\t# \t\tself.permission_set[item_name].actions = defaultActions\n\t# \tif self.related_objects\n\t# \t\tself.permission_set[item_name].related_objects = defaultRelatedObjects\n\t# \tif self.fields\n\t# \t\tself.permission_set[item_name].readable_fields = defaultReadableFields\n\t# \t\tself.permission_set[item_name].editable_fields = defaultEditableFields\n\tunless options.permission_set\n\t\toptions.permission_set = {}\n\tif !(options.permission_set?.admin)\n\t\toptions.permission_set.admin = _.clone(self.permission_set[\"admin\"])\n\tif !(options.permission_set?.user)\n\t\toptions.permission_set.user = _.clone(self.permission_set[\"user\"])\n\t_.each options.permission_set, (item, item_name)->\n\t\tif !self.permission_set[item_name]\n\t\t\tself.permission_set[item_name] = {}\n\t\tself.permission_set[item_name] = _.extend(_.clone(self.permission_set[item_name]), item)\n\n\t# 前端根据permissions改写field相关属性，后端只要走默认属性就行，不需要改写\n\tif Meteor.isClient\n\t\tpermissions = options.permissions\n\t\tdisabled_list_views = permissions?.disabled_list_views\n\t\tif disabled_list_views?.length\n\t\t\tdefaultListViewId = options.list_views?.all?._id\n\t\t\tif defaultListViewId\n\t\t\t\t# 把视图权限配置中默认的all视图id转换成all关键字\n\t\t\t\tpermissions.disabled_list_views = _.map disabled_list_views, (list_view_item) ->\n\t\t\t\t\treturn if defaultListViewId == list_view_item then \"all\" else list_view_item\n\t\tself.permissions = new ReactiveVar(permissions)\n#\t\t_.each self.fields, (field, field_name)->\n#\t\t\tif field\n#\t\t\t\tif _.indexOf(permissions?.unreadable_fields, field_name) < 0\n#\t\t\t\t\tif field.hidden\n#\t\t\t\t\t\treturn\n#\t\t\t\t\tif _.indexOf(permissions?.uneditable_fields, field_name) > -1\n#\t\t\t\t\t\tfield.readonly = true\n#\t\t\t\t\t\tfield.disabled = true\n#\t\t\t\t\t\t# 当只读时，如果不去掉必填字段，autoform是会报错的\n#\t\t\t\t\t\tfield.required = false\n#\t\t\t\telse\n#\t\t\t\t\tfield.hidden = true\n\telse\n\t\tself.permissions = null\n\n\t_db = Creator.createCollection(options)\n\n\tCreator.Collections[_db._name] = _db\n\n\tself.db = _db\n\n\tself._collection_name = _db._name\n\n\tschema = Creator.getObjectSchema(self)\n\tself.schema = new SimpleSchema(schema)\n\tif self.name != \"users\" and self.name != \"cfs.files.filerecord\" && !self.is_view && !_.contains([\"flows\", \"forms\", \"instances\", \"organizations\", \"action_field_updates\", \"object_listviews\"], self.name)\n\t\tif Meteor.isClient\n\t\t\t_db.attachSchema(self.schema, {replace: true})\n\t\telse\n\t\t\t_db.attachSchema(self.schema, {replace: true})\n\tif self.name == \"users\"\n\t\t_db._simpleSchema = self.schema\n\n\tif _.contains([\"flows\", \"forms\", \"instances\", \"organizations\"], self.name)\n\t\tif Meteor.isClient\n\t\t\t_db.attachSchema(self.schema, {replace: true})\n\n\tCreator.objectsByName[self._collection_name] = self\n\n\treturn self\n\n# Creator.Object.prototype.i18n = ()->\n# \t# set object label\n# \tself = this\n\n# \tkey = self.name\n# \tif t(key) == key\n# \t\tif !self.label\n# \t\t\tself.label = self.name\n# \telse\n# \t\tself.label = t(key)\n\n# \t# set field labels\n# \t_.each self.fields, (field, field_name)->\n# \t\tfkey = self.name + \"_\" + field_name\n# \t\tif t(fkey) == fkey\n# \t\t\tif !field.label\n# \t\t\t\tfield.label = field_name\n# \t\telse\n# \t\t\tfield.label = t(fkey)\n# \t\tself.schema?._schema?[field_name]?.label = field.label\n\n\n# \t# set listview labels\n# \t_.each self.list_views, (item, item_name)->\n# \t\ti18n_key = self.name + \"_listview_\" + item_name\n# \t\tif t(i18n_key) == i18n_key\n# \t\t\tif !item.label\n# \t\t\t\titem.label = item_name\n# \t\telse\n# \t\t\titem.label = t(i18n_key)\n\n\nCreator.getObjectODataRouterPrefix = (object)->\n\treturn \"/api/odata/v4\"\n\t# if object\n\t# \tif !object.database_name || object.database_name == 'meteor-mongo'\n\t# \t\treturn \"/api/odata/v4\"\n\t# \telse\n\t# \t\treturn \"/api/odata/#{object.database_name}\"\n\n# if Meteor.isClient\n\n# \tMeteor.startup ->\n# \t\tTracker.autorun ->\n# \t\t\tif Session.get(\"steedos-locale\") && Creator.bootstrapLoaded?.get()\n# \t\t\t\t_.each Creator.objectsByName, (object, object_name)->\n# \t\t\t\t\tobject.i18n()\n\nMeteor.startup ->\n\tif !Creator.bootstrapLoaded && Creator.Objects\n\t\t_.each Creator.Objects, (object)->\n\t\t\tnew Creator.Object(object)\n\n","var clone;\n\nclone = require('clone');\n\nCreator.objectsByName = {};\n\nCreator.formatObjectName = function(object_name) {\n  if (object_name.startsWith('cfs.files.')) {\n    object_name = object_name.replace(new RegExp('\\\\.', 'g'), '_');\n  }\n  return object_name;\n};\n\nCreator.Object = function(options) {\n  var _baseObject, _db, defaultListViewId, defaultView, disabled_list_views, permissions, ref, ref1, ref2, ref3, schema, self;\n  _baseObject = Creator.baseObject;\n  if (Meteor.isClient) {\n    _baseObject = {\n      actions: Creator.baseObject.actions,\n      fields: {},\n      triggers: {},\n      permission_set: {}\n    };\n  }\n  self = this;\n  if (!options.name) {\n    console.error(options);\n    throw new Error('Creator.Object options must specify name');\n  }\n  self._id = options._id || options.name;\n  self.space = options.space;\n  self.name = options.name;\n  self.label = options.label;\n  self.icon = options.icon;\n  self.description = options.description;\n  self.is_view = options.is_view;\n  self.form = options.form;\n  self.relatedList = options.relatedList;\n  self.related_lists = options.related_lists;\n  self.hasImportTemplates = options.hasImportTemplates;\n  self.version = options.version || 1.0;\n  if (!_.isBoolean(options.is_enable) || options.is_enable === true) {\n    self.is_enable = true;\n  } else {\n    self.is_enable = false;\n  }\n  if (Meteor.isClient) {\n    if (_.has(options, 'allow_customActions')) {\n      self.allow_customActions = options.allow_customActions;\n    }\n    if (_.has(options, 'exclude_actions')) {\n      self.exclude_actions = options.exclude_actions;\n    }\n    if (_.has(options, 'allow_relatedList')) {\n      self.allow_relatedList = options.allow_relatedList;\n    }\n  }\n  self.enable_search = options.enable_search;\n  self.enable_files = options.enable_files;\n  self.enable_tasks = options.enable_tasks;\n  self.enable_notes = options.enable_notes;\n  self.enable_audit = options.enable_audit;\n  self.enable_events = options.enable_events;\n  if (options.paging) {\n    self.paging = options.paging;\n  }\n  self.hidden = options.hidden;\n  self.enable_api = (options.enable_api === void 0) || options.enable_api;\n  self.custom = options.custom;\n  self.enable_share = options.enable_share;\n  self.enable_instances = options.enable_instances;\n  self.enable_process = options.enable_process;\n  if (Meteor.isClient) {\n    if (Creator.isCloudAdminSpace(Session.get(\"spaceId\"))) {\n      self.enable_tree = false;\n    } else {\n      self.enable_tree = options.enable_tree;\n      self.sidebar = _.clone(options.sidebar);\n    }\n  } else {\n    self.sidebar = _.clone(options.sidebar);\n    self.enable_tree = options.enable_tree;\n  }\n  self.open_window = options.open_window;\n  self.filter_company = options.filter_company;\n  self.calendar = _.clone(options.calendar);\n  self.enable_chatter = options.enable_chatter;\n  self.enable_trash = options.enable_trash;\n  self.enable_space_global = options.enable_space_global;\n  self.enable_approvals = options.enable_approvals;\n  self.enable_follow = options.enable_follow;\n  self.enable_workflow = options.enable_workflow;\n  self.enable_inline_edit = options.enable_inline_edit;\n  self.details = options.details;\n  self.masters = options.masters;\n  self.lookup_details = options.lookup_details;\n  if (_.has(options, 'in_development')) {\n    self.in_development = options.in_development;\n  }\n  self.idFieldName = '_id';\n  if (options.database_name) {\n    self.database_name = options.database_name;\n  }\n  if (!options.fields) {\n    console.error(options);\n    throw new Error('Creator.Object options must specify fields');\n  }\n  self.fields = clone(options.fields);\n  _.each(self.fields, function(field, field_name) {\n    if (field.is_name) {\n      self.NAME_FIELD_KEY = field_name;\n    } else if (field_name === 'name' && !self.NAME_FIELD_KEY) {\n      self.NAME_FIELD_KEY = field_name;\n    }\n    if (field.primary) {\n      self.idFieldName = field_name;\n    }\n    if (Meteor.isClient) {\n      if (Creator.isCloudAdminSpace(Session.get(\"spaceId\"))) {\n        if (field_name === 'space') {\n          field.filterable = true;\n          return field.hidden = false;\n        }\n      }\n    }\n  });\n  if (!options.database_name || options.database_name === 'meteor-mongo') {\n    _.each(_baseObject.fields, function(field, field_name) {\n      if (!self.fields[field_name]) {\n        self.fields[field_name] = {};\n      }\n      return self.fields[field_name] = _.extend(_.clone(field), self.fields[field_name]);\n    });\n  }\n  _.each(self.fields, function(field, field_name) {\n    if (field.type === 'autonumber') {\n      return field.readonly = true;\n    } else if (field.type === 'formula') {\n      return field.readonly = true;\n    } else if (field.type === 'summary') {\n      return field.readonly = true;\n    }\n  });\n  self.list_views = {};\n  defaultView = Creator.getObjectDefaultView(self.name);\n  _.each(options.list_views, function(item, item_name) {\n    var oitem;\n    oitem = Creator.convertListView(defaultView, item, item_name);\n    return self.list_views[item_name] = oitem;\n  });\n  self.triggers = _.clone(_baseObject.triggers);\n  _.each(options.triggers, function(item, item_name) {\n    if (!self.triggers[item_name]) {\n      self.triggers[item_name] = {};\n    }\n    self.triggers[item_name].name = item_name;\n    return self.triggers[item_name] = _.extend(_.clone(self.triggers[item_name]), item);\n  });\n  self.actions = _.clone(_baseObject.actions);\n  _.each(options.actions, function(item, item_name) {\n    var copyItem;\n    if (!self.actions[item_name]) {\n      self.actions[item_name] = {};\n    }\n    copyItem = _.clone(self.actions[item_name]);\n    delete self.actions[item_name];\n    self.actions[item_name] = _.extend(copyItem, item);\n    return self.actions[item_name].object_name = self.name;\n  });\n  _.each(self.actions, function(item, item_name) {\n    return item.name = item_name;\n  });\n  self.related_objects = Creator.getObjectRelateds(self.name);\n  self.permission_set = _.clone(_baseObject.permission_set);\n  if (!options.permission_set) {\n    options.permission_set = {};\n  }\n  if (!((ref = options.permission_set) != null ? ref.admin : void 0)) {\n    options.permission_set.admin = _.clone(self.permission_set[\"admin\"]);\n  }\n  if (!((ref1 = options.permission_set) != null ? ref1.user : void 0)) {\n    options.permission_set.user = _.clone(self.permission_set[\"user\"]);\n  }\n  _.each(options.permission_set, function(item, item_name) {\n    if (!self.permission_set[item_name]) {\n      self.permission_set[item_name] = {};\n    }\n    return self.permission_set[item_name] = _.extend(_.clone(self.permission_set[item_name]), item);\n  });\n  if (Meteor.isClient) {\n    permissions = options.permissions;\n    disabled_list_views = permissions != null ? permissions.disabled_list_views : void 0;\n    if (disabled_list_views != null ? disabled_list_views.length : void 0) {\n      defaultListViewId = (ref2 = options.list_views) != null ? (ref3 = ref2.all) != null ? ref3._id : void 0 : void 0;\n      if (defaultListViewId) {\n        permissions.disabled_list_views = _.map(disabled_list_views, function(list_view_item) {\n          if (defaultListViewId === list_view_item) {\n            return \"all\";\n          } else {\n            return list_view_item;\n          }\n        });\n      }\n    }\n    self.permissions = new ReactiveVar(permissions);\n  } else {\n    self.permissions = null;\n  }\n  _db = Creator.createCollection(options);\n  Creator.Collections[_db._name] = _db;\n  self.db = _db;\n  self._collection_name = _db._name;\n  schema = Creator.getObjectSchema(self);\n  self.schema = new SimpleSchema(schema);\n  if (self.name !== \"users\" && self.name !== \"cfs.files.filerecord\" && !self.is_view && !_.contains([\"flows\", \"forms\", \"instances\", \"organizations\", \"action_field_updates\", \"object_listviews\"], self.name)) {\n    if (Meteor.isClient) {\n      _db.attachSchema(self.schema, {\n        replace: true\n      });\n    } else {\n      _db.attachSchema(self.schema, {\n        replace: true\n      });\n    }\n  }\n  if (self.name === \"users\") {\n    _db._simpleSchema = self.schema;\n  }\n  if (_.contains([\"flows\", \"forms\", \"instances\", \"organizations\"], self.name)) {\n    if (Meteor.isClient) {\n      _db.attachSchema(self.schema, {\n        replace: true\n      });\n    }\n  }\n  Creator.objectsByName[self._collection_name] = self;\n  return self;\n};\n\nCreator.getObjectODataRouterPrefix = function(object) {\n  return \"/api/odata/v4\";\n};\n\nMeteor.startup(function() {\n  if (!Creator.bootstrapLoaded && Creator.Objects) {\n    return _.each(Creator.Objects, function(object) {\n      return new Creator.Object(object);\n    });\n  }\n});\n","Creator.getSelectOptions = (fieldSchema) ->\n\toptions = fieldSchema.options\n\tunless options\n\t\treturn\n\tdata_type = fieldSchema.data_type\n\tif !_.isFunction(options) and data_type and data_type != 'text'\n\t\t# 零代码界面配置options选项值只支持字符串，所以当data_type为数值或boolean时，只能强行把选项值先转换为对应的类型\n\t\toptions.forEach (optionItem) ->\n\t\t\tif typeof optionItem.value != 'string'\n\t\t\t\treturn\n\t\t\tif [\n\t\t\t\t'number'\n\t\t\t\t'currency'\n\t\t\t\t'percent'\n\t\t\t].indexOf(data_type) > -1\n\t\t\t\toptionItem.value = Number(optionItem.value)\n\t\t\telse if data_type == 'boolean'\n\t\t\t\t# 只有为true才为真\n\t\t\t\toptionItem.value = optionItem.value == 'true'\n\treturn options\n\nCreator.getObjectSchema = (obj) ->\n\tunless obj\n\t\treturn\n\tschema = {}\n\n\tfieldsArr = []\n\n\t_.each obj.fields , (field, field_name)->\n\t\tif !_.has(field, \"name\")\n\t\t\tfield.name = field_name\n\t\tfieldsArr.push field\n\n\t_.each _.sortBy(fieldsArr, \"sort_no\"), (field)->\n\n\t\tfield_name = field.name\n\n\t\tfs = {}\n\t\tif field.regEx\n\t\t\tfs.regEx = field.regEx\n\t\tfs.autoform = {}\n\t\tfs.autoform.multiple = field.multiple\n\t\tfs.autoform.reference_to = field.reference_to\n\n\t\tautoform_type = field.autoform?.type\n\n\t\tif field.type == \"text\" or field.type == \"phone\"\n\t\t\tfs.type = String\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tfs.autoform.type = \"tags\"\n\t\telse if field.type == \"[text]\" or field.type == \"[phone]\"\n\t\t\tfs.type = [String]\n\t\t\tfs.autoform.type = \"tags\"\n\t\telse if field.type == 'code'\n\t\t\tfs.type = String\n\t\t\tfs.autoform.type = \"widearea\"\n\t\t\tfs.autoform.rows = field.rows || 12\n\t\t\tif field.language\n\t\t\t\tfs.autoform.language = field.language\n\t\telse if field.type == \"textarea\"\n\t\t\tfs.type = String\n\t\t\tfs.autoform.type = \"widearea\"\n\t\t\tfs.autoform.rows = field.rows || 2\n\t\telse if field.type == \"password\"\n\t\t\tfs.type = String\n\t\t\tfs.autoform.type = \"password\"\n\t\telse if field.type == \"date\"\n\t\t\tfs.type = Date\n\t\t\tif Meteor.isClient\n\t\t\t\tif Steedos.isMobile() || Steedos.isPad()\n\t\t\t\t\tif Steedos.isiOS()\n\t\t\t\t\t\t# Fix ios 14, 手机客户端待审核文件日期控件显示故障 #991，ios统一用PC端一样的js控件\n\t\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\t\t\ttimezoneId: \"utc\"\n\t\t\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\t\t\ttype: \"date\"\n\t\t\t\t\t\t\t\tdisplayFormat: \"yyyy-MM-dd\"\n\t\t\t\t\t\t\t\tpickerType: \"rollers\"\n\t\t\t\t\telse\n\t\t\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\t\ttype: \"steedos-date-mobile\"\n\t\t\t\t\t\t\tdateMobileOptions:\n\t\t\t\t\t\t\t\ttype: \"date\"\n\t\t\t\telse\n\t\t\t\t\tfs.autoform.outFormat = 'yyyy-MM-dd';\n\t\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\t\ttimezoneId: \"utc\"\n\t\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\t\ttype: \"date\"\n\t\t\t\t\t\t\tdisplayFormat: \"yyyy-MM-dd\"\n\t\telse if field.type == \"time\"\n\t\t\tfs.type = Date\n\t\t\tif Meteor.isClient\n\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\ttimezoneId: \"utc\"\n\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\ttype: \"time\"\n\t\t\t\t\t\tdisplayFormat: \"HH:mm\"\n\t\telse if field.type == \"datetime\"\n\t\t\tfs.type = Date\n\t\t\tif Meteor.isClient\n\t\t\t\tif Steedos.isMobile() || Steedos.isPad()\n\t\t\t\t\tif Steedos.isiOS()\n\t\t\t\t\t\t# Fix ios 14, 手机客户端待审核文件日期控件显示故障 #991，ios统一用PC端一样的js控件\n\t\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\t\t\ttype: \"datetime\"\n\t\t\t\t\t\t\t\tdisplayFormat: \"yyyy-MM-dd HH:mm\"\n\t\t\t\t\t\t\t\tpickerType: \"rollers\"\n\t\t\t\t\telse\n\t\t\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\t\ttype: \"steedos-date-mobile\"\n\t\t\t\t\t\t\tdateMobileOptions:\n\t\t\t\t\t\t\t\ttype: \"datetime\"\n\t\t\t\telse\n\t\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\t\ttype: \"datetime\"\n\t\t\t\t\t\t\tdisplayFormat: \"yyyy-MM-dd HH:mm\"\n\t\telse if field.type == \"[Object]\"\n\t\t\tfs.type = [Object]\n\t\telse if field.type == \"html\"\n\t\t\tfs.type = String\n\t\t\tif Meteor.isClient\n\t\t\t\tfs.autoform.type = 'steedosHtml';\n\t\t\t# if Meteor.isClient\n\t\t\t# \tlocale = Steedos.locale()\n\t\t\t# \tif locale == \"zh-cn\" || locale == \"zh-CN\"\n\t\t\t# \t\tlocale = \"zh-CN\"\n\t\t\t# \telse\n\t\t\t# \t\tlocale = \"en-US\"\n\t\t\t# \tfs.autoform.afFieldInput =\n\t\t\t# \t\ttype: \"summernote\"\n\t\t\t# \t\tclass: 'summernote-editor'\n\t\t\t# \t\tsettings:\n\t\t\t# \t\t\theight: 200\n\t\t\t# \t\t\tdialogsInBody: true\n\t\t\t# \t\t\ttoolbar:  [\n\t\t\t# \t\t\t\t['font1', ['style']],\n\t\t\t# \t\t\t\t['font2', ['bold', 'underline', 'italic', 'clear']],\n\t\t\t# \t\t\t\t['font3', ['fontname']],\n\t\t\t# \t\t\t\t['color', ['color']],\n\t\t\t# \t\t\t\t['para', ['ul', 'ol', 'paragraph']],\n\t\t\t# \t\t\t\t['table', ['table']],\n\t\t\t# \t\t\t\t['insert', ['link', 'picture']],\n\t\t\t# \t\t\t\t['view', ['codeview']]\n\t\t\t# \t\t\t]\n\t\t\t# \t\t\tfontNames: ['Arial', 'Comic Sans MS', 'Courier New', 'Helvetica', 'Impact', '宋体','黑体','微软雅黑','仿宋','楷体','隶书','幼圆']\n\t\t\t# \t\t\tlang: locale\n\n\t\telse if (field.type == \"lookup\" or field.type == \"master_detail\")\n\t\t\tfs.type = String\n\t\t\tfs.autoform.showIcon = field.showIcon\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\n\t\t\tif !field.hidden\n\n\t\t\t\tfs.autoform.filters = field.filters\n\n\t\t\t\tfs.autoform.dependOn = field.depend_on\n\n\t\t\t\tif field.beforeOpenFunction\n\t\t\t\t\tfs.beforeOpenFunction = field.beforeOpenFunction\n\n\t\t\t\tfs.filtersFunction = if field.filtersFunction then field.filtersFunction else Creator.evaluateFilters\n\n\t\t\t\tif field.optionsFunction\n\t\t\t\t\tfs.optionsFunction = field.optionsFunction\n\n\t\t\t\tif field.reference_to\n\n\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\tif field.createFunction && _.isFunction(field.createFunction)\n\t\t\t\t\t\t\tfs.createFunction = field.createFunction\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tif _.isString(field.reference_to)\n\t\t\t\t\t\t\t\t_ref_obj = Creator.Objects[field.reference_to]\n\t\t\t\t\t\t\t\tif _ref_obj?.permissions?.allowCreate\n\t\t\t\t\t\t\t\t\tfs.autoform.create = true\n\t\t\t\t\t\t\t\t\tfs.createFunction = (lookup_field)->\n\t\t\t\t\t\t\t\t\t\tModal.show(\"CreatorObjectModal\", {\n\t\t\t\t\t\t\t\t\t\t\tcollection: \"Creator.Collections.#{Creator.getCollection(field.reference_to)._name}\",\n\t\t\t\t\t\t\t\t\t\t\tformId: \"new#{field.reference_to.replace('.','_')}\",\n\t\t\t\t\t\t\t\t\t\t\tobject_name: \"#{field.reference_to}\",\n\t\t\t\t\t\t\t\t\t\t\toperation: \"insert\",\n\t\t\t\t\t\t\t\t\t\t\tonSuccess: (operation, result)->\n\t\t\t\t\t\t\t\t\t\t\t\tobject = Creator.getObject(result.object_name)\n\t\t\t\t\t\t\t\t\t\t\t\tif result.object_name == \"objects\"\n\t\t\t\t\t\t\t\t\t\t\t\t\tlookup_field.addItems([{label: result.value.label, value: result.value.name, icon: result.value.icon}], result.value.name)\n\t\t\t\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\t\t\t\tlookup_field.addItems([{label: result.value[object.NAME_FIELD_KEY] || result.value.label || result.value.name, value: result._id}], result._id)\n\t\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\tfs.autoform.create = false\n\n\t\t\t\t\tif _.isBoolean(field.create)\n\t\t\t\t\t\tfs.autoform.create = field.create\n\n\t\t\t\t\tif field.reference_sort\n\t\t\t\t\t\tfs.autoform.optionsSort = field.reference_sort\n\n\t\t\t\t\tif field.reference_limit\n\t\t\t\t\t\tfs.autoform.optionsLimit = field.reference_limit\n\t\t\t\t\tif field.reference_to_field\n\t\t\t\t\t\tfs.autoform.referenceToField = field.reference_to_field\n\n\t\t\t\t\tif field.reference_to == \"users\"\n\t\t\t\t\t\tfs.autoform.type = \"selectuser\"\n\t\t\t\t\t\tif !field.hidden && !field.omit\n\t\t\t\t\t\t\t# is_company_limited表示过滤数据时是否只显示本分部下的数据\n\t\t\t\t\t\t\t# is_company_limited可以被改写覆盖成true/false或其他function\n\t\t\t\t\t\t\tif field.is_company_limited == undefined\n\t\t\t\t\t\t\t\t# 未定义is_company_limited属性时默认处理逻辑：\n\t\t\t\t\t\t\t\t# 对当前对象有viewAllRecords权限则不限制所属分部列表查看权限，否则只显示当前所属分部\n\t\t\t\t\t\t\t\t# 注意不是reference_to对象的viewAllRecords权限，而是当前对象的\n\t\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\t\tpermissions = obj.permissions\n\t\t\t\t\t\t\t\t\tisUnLimited = permissions?.viewAllRecords\n\t\t\t\t\t\t\t\t\tif _.include([\"organizations\", \"users\", \"space_users\"], obj.name)\n\t\t\t\t\t\t\t\t\t\t# 如果字段所属对象是用户或组织，则是否限制显示所属分部部门与modifyAllRecords权限关联\n\t\t\t\t\t\t\t\t\t\tisUnLimited = permissions?.modifyAllRecords\n\t\t\t\t\t\t\t\t\tif isUnLimited\n\t\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = false\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = true\n\t\t\t\t\t\t\telse if _.isFunction field.is_company_limited\n\t\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\t\t# 传入当前对象的权限，在函数中根据权限计算是否要限制只查看本分部\n\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited(obj.permissions)\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t# 服务端用不到is_company_limited\n\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = true\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited\n\t\t\t\t\telse if field.reference_to == \"organizations\"\n\t\t\t\t\t\tfs.autoform.type = \"selectorg\"\n\t\t\t\t\t\tif !field.hidden && !field.omit\n\t\t\t\t\t\t\t# is_company_limited表示过滤数据时是否只显示本分部下的数据\n\t\t\t\t\t\t\t# is_company_limited可以被改写覆盖成true/false或其他function\n\t\t\t\t\t\t\tif field.is_company_limited == undefined\n\t\t\t\t\t\t\t\t# 未定义is_company_limited属性时默认处理逻辑：\n\t\t\t\t\t\t\t\t# 对当前对象有viewAllRecords权限则不限制所属分部列表查看权限，否则只显示当前所属分部\n\t\t\t\t\t\t\t\t# 注意不是reference_to对象的viewAllRecords权限，而是当前对象的\n\t\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\t\tpermissions = obj.permissions\n\t\t\t\t\t\t\t\t\tisUnLimited = permissions?.viewAllRecords\n\t\t\t\t\t\t\t\t\tif _.include([\"organizations\", \"users\", \"space_users\"], obj.name)\n\t\t\t\t\t\t\t\t\t\t# 如果字段所属对象是用户或组织，则是否限制显示所属分部部门与modifyAllRecords权限关联\n\t\t\t\t\t\t\t\t\t\tisUnLimited = permissions?.modifyAllRecords\n\t\t\t\t\t\t\t\t\tif isUnLimited\n\t\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = false\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = true\n\t\t\t\t\t\t\telse if _.isFunction field.is_company_limited\n\t\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\t\t# 传入当前对象的权限，在函数中根据权限计算是否要限制只查看本分部\n\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited(obj.permissions)\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t# 服务端用不到is_company_limited\n\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = true\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited\n\t\t\t\t\telse\n\t\t\t\t\t\tif typeof(field.reference_to) == \"function\"\n\t\t\t\t\t\t\t_reference_to = field.reference_to()\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t_reference_to = field.reference_to\n\n\t\t\t\t\t\tif _.isArray(_reference_to)\n\t\t\t\t\t\t\tfs.type = Object\n\t\t\t\t\t\t\tfs.blackbox = true\n\t\t\t\t\t\t\tfs.autoform.objectSwitche = true\n\n\t\t\t\t\t\t\tschema[field_name + \".o\"] = {\n\t\t\t\t\t\t\t\ttype: String\n\t\t\t\t\t\t\t\tautoform: {omit: true}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tschema[field_name + \".ids\"] = {\n\t\t\t\t\t\t\t\ttype: [String]\n\t\t\t\t\t\t\t\tautoform: {omit: true}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t_reference_to = [_reference_to]\n\n\t\t\t\t\t\t_object = Creator.Objects[_reference_to[0]]\n\t\t\t\t\t\tif _object and _object.enable_tree\n\t\t\t\t\t\t\tfs.autoform.type = \"selectTree\"\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tfs.autoform.type = \"steedosLookups\"\n\t\t\t\t\t\t\tfs.autoform.optionsMethod = field.optionsMethod || \"creator.object_options\"\n\n\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\tfs.autoform.optionsMethodParams = ()->\n\t\t\t\t\t\t\t\t\treturn {space: Session.get(\"spaceId\")}\n\t\t\t\t\t\t\t\tfs.autoform.references = []\n\t\t\t\t\t\t\t\t_reference_to.forEach (_reference)->\n\t\t\t\t\t\t\t\t\t_object = Creator.Objects[_reference]\n\t\t\t\t\t\t\t\t\tif _object\n\t\t\t\t\t\t\t\t\t\tfs.autoform.references.push {\n\t\t\t\t\t\t\t\t\t\t\tobject: _reference\n\t\t\t\t\t\t\t\t\t\t\tlabel: _object?.label\n\t\t\t\t\t\t\t\t\t\t\ticon: _object?.icon\n\t\t\t\t\t\t\t\t\t\t\tlink: ()->\n\t\t\t\t\t\t\t\t\t\t\t\treturn \"/app/#{Session.get('app_id')}/#{_reference}/view/\"\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tfs.autoform.references.push {\n\t\t\t\t\t\t\t\t\t\t\tobject: _reference\n\t\t\t\t\t\t\t\t\t\t\tlink: ()->\n\t\t\t\t\t\t\t\t\t\t\t\treturn \"/app/#{Session.get('app_id')}/#{_reference}/view/\"\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\telse\n\t\t\t\t\tfs.autoform.type = \"steedosLookups\"\n\t\t\t\t\tfs.autoform.defaultIcon = field.defaultIcon\n\n\t\telse if field.type == \"select\"\n\t\t\tfs.type = String\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tfs.autoform.type = \"steedosLookups\"\n\t\t\t\tfs.autoform.showIcon = false\n\t\t\t\tfs.autoform.options = field.options\n\t\t\telse\n\t\t\t\tfs.autoform.type = \"select\"\n\t\t\t\tfs.autoform.options = field.options\n\t\t\t\tif _.has(field, 'firstOption')\n\t\t\t\t\tfs.autoform.firstOption = field.firstOption\n\t\t\t\telse\n\t\t\t\t\tfs.autoform.firstOption = \"\"\n\t\t\t# 因为列表视图右侧过滤器还是用的老表单的lookup和select控件，所以上面的代码始终保持原样需要执行\n\t\t\t# 下面是配置了data_type时，额外处理的逻辑\n\t\t\tif field.data_type and field.data_type != \"text\"\n\t\t\t\tif [\"number\", \"currency\", \"percent\"].indexOf(field.data_type) > -1\n\t\t\t\t\tfsType = Number\n\t\t\t\t\tfs.decimal = true\n\t\t\t\telse if field.data_type == \"boolean\"\n\t\t\t\t\tfsType = Boolean\n\t\t\t\telse\n\t\t\t\t\tfsType = String\n\t\t\t\tfs.type = fsType\n\t\t\t\tif field.multiple\n\t\t\t\t\tfs.type = [fsType]\n\t\t\t\t\t\n\t\t\t\tfs.autoform.options = Creator.getSelectOptions(field)\n\t\telse if field.type == \"currency\"\n\t\t\tfs.type = Number\n\t\t\tfs.autoform.type = \"steedosNumber\"\n\t\t\tfs.autoform.precision = field.precision || 18\n\t\t\tif field?.scale\n\t\t\t\tfs.autoform.scale = field.scale\n\t\t\t\tfs.decimal = true\n\t\t\telse if field?.scale != 0\n\t\t\t\tfs.autoform.scale = 2\n\t\t\t\tfs.decimal = true\n\t\telse if field.type == \"number\"\n\t\t\tfs.type = Number\n\t\t\tfs.autoform.type = \"steedosNumber\"\n\t\t\tfs.autoform.precision = field.precision || 18\n\t\t\tif field?.scale\n\t\t\t\tfs.autoform.scale = field.scale\n\t\t\t\tfs.decimal = true\n\t\telse if field.type == \"boolean\"\n\t\t\tfs.type = Boolean\n\t\t\tif field.readonly\n\t\t\t\tfs.autoform.disabled = true\n\t\t\tfs.autoform.type = \"steedos-boolean-checkbox\"\n\t\telse if field.type == \"toggle\"\n\t\t\tfs.type = Boolean\n\t\t\tif field.readonly\n\t\t\t\tfs.autoform.disabled = true\n\t\t\tfs.autoform.type = \"steedos-boolean-toggle\"\n\t\telse if field.type == \"reference\"\n\t\t\tfs.type = String\n\t\telse if field.type == \"checkbox\"\n\t\t\tfs.type = [String]\n\t\t\tfs.autoform.type = \"select-checkbox\"\n\t\t\tfs.autoform.options = field.options\n\t\telse if field.type == \"file\"\n\t\t\tcollectionName = field.collection || \"files\" # collection 默认是 'files'\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: collectionName\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = collectionName\n\t\telse if field.type == \"filesize\"\n\t\t\tfs.type = Number\n\t\t\tfs.autoform.type = 'filesize'\n\t\telse if field.type == \"Object\" || field.type == \"object\"\n\t\t\tfs.type = Object\n\t\telse if field.type == \"grid\" || field.type == \"table\"\n\t\t\tfs.type = Array\n\t\t\tfs.autoform.editable = true\n\t\t\tfs.autoform.type = \"steedosGrid\"\n\n\t\t\tschema[field_name + \".$\"] =\n\t\t\t\ttype: Object\n\t\telse if field.type == \"image\"\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: 'images'\n\t\t\t\t\t\taccept: 'image/*'\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = 'images'\n\t\t\t\tfs.autoform.accept = 'image/*'\n\t\telse if field.type == \"avatar\"\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: 'avatars'\n\t\t\t\t\t\taccept: 'image/*'\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = 'avatars'\n\t\t\t\tfs.autoform.accept = 'image/*'\n\t\telse if field.type == \"audio\"\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: 'audios'\n\t\t\t\t\t\taccept: 'audio/*'\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = 'audios'\n\t\t\t\tfs.autoform.accept = 'audio/*'\n\t\telse if field.type == \"video\"\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: 'videos'\n\t\t\t\t\t\taccept: 'video/*'\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = 'videos'\n\t\t\t\tfs.autoform.accept = 'video/*'\n\t\telse if field.type == \"location\"\n\t\t\tfs.type = Object\n\t\t\tfs.autoform.type = \"location\"\n\t\t\tfs.autoform.system = field.system || \"wgs84\"\n\t\t\tfs.blackbox = true\n\t\telse if field.type == \"markdown\"\n\t\t\tfs.type = String\n\t\t\tfs.autoform.type = \"text\"\n\t\telse if field.type == 'url'\n\t\t\tfs.type = String\n\t\t\t# fs.regEx = SimpleSchema.RegEx.Url\n\t\t\tfs.autoform.type = 'steedosUrl'\n\t\telse if field.type == 'email'\n\t\t\tfs.type = String\n\t\t\tfs.regEx = SimpleSchema.RegEx.Email\n\t\t\tfs.autoform.type = 'steedosEmail'\n\t\telse if field.type == 'autonumber'\n\t\t\tfs.type = String\n\t\telse if field.type == 'color'\n\t\t\tfs.type = String\n\t\telse if field.type == 'formula'\n\t\t\tfs = Creator.getObjectSchema({fields: {field: Object.assign({}, field, {type: field.data_type})}})[field.name]\n\t\telse if field.type == 'summary'\n\t\t\tfs = Creator.getObjectSchema({fields: {field: Object.assign({}, field, {type: field.data_type})}})[field.name]\n\t\t# else if field.type == 'select'\n\t\t# \tfs = Creator.getObjectSchema({fields: {field: Object.assign({}, field, {type: field.data_type})}})[field.name]\n\t\telse if field.type == 'percent'\n\t\t\tfs.type = Number\n\t\t\tfs.autoform.type = \"steedosNumber\"\n\t\t\tfs.autoform.precision = field.precision || 18\n\t\t\tunless _.isNumber(field.scale)\n\t\t\t\t# 没配置小数位数则按小数位数0来处理，即默认显示为整数的百分比，比如20%，此时控件可以输入2位小数，转成百分比就是整数\n\t\t\t\tfield.scale = 0\n\t\t\t# autoform控件中小数位数始终比配置的位数多2位\n\t\t\tfs.autoform.scale = field.scale + 2\n\t\t\tfs.decimal = true\n\t\telse\n\t\t\tfs.type = field.type\n\n\t\tif field.label\n\t\t\tfs.label = field.label\n\n#\t\tif field.allowedValues\n#\t\t\tfs.allowedValues = field.allowedValues\n\n\t\tif !field.required\n\t\t\tfs.optional = true\n\n\t\t# [签约对象同时配置了company_ids必填及uneditable_fields造成部分用户新建签约对象时报错 #192](https://github.com/steedos/steedos-project-dzug/issues/192)\n\t\t# 后台始终设置required为false\n\t\tif !Meteor.isClient\n\t\t\tfs.optional = true\n\n\t\tif field.unique\n\t\t\tfs.unique = true\n\n\t\tif field.omit\n\t\t\tfs.autoform.omit = true\n\n\t\tif field.group\n\t\t\tfs.autoform.group = field.group\n\n\t\tif field.is_wide\n\t\t\tfs.autoform.is_wide = true\n\n\t\tif field.hidden\n\t\t\tfs.autoform.type = \"hidden\"\n\n\t\tif (field.type == \"select\") or (field.type == \"lookup\") or (field.type == \"master_detail\")\n\t\t\tif typeof(field.filterable) == 'undefined'\n\t\t\t\tfield.filterable = true\n\t\tif field.name == 'name' || field.is_name\n\t\t\tif typeof(field.searchable) == 'undefined'\n\t\t\t\tfield.searchable = true\n\n\t\tif autoform_type\n\t\t\tfs.autoform.type = autoform_type\n\n\t\tif field.defaultValue\n\t\t\tif Meteor.isClient and Creator.Formular.checkFormula(field.defaultValue)\n\t\t\t\tfs.autoform.defaultValue = ()->\n\t\t\t\t\treturn Creator.Formular.run(field.defaultValue, {userId: Meteor.userId(), spaceId: Session.get(\"spaceId\"), now: new Date()})\n\t\t\telse\n\t\t\t\tfs.autoform.defaultValue = field.defaultValue\n\t\t\t# \tif !_.isFunction(field.defaultValue)\n\t\t\t# \t\tfs.defaultValue = field.defaultValue\n\n\t\tif field.readonly\n\t\t\tfs.autoform.readonly = true\n\n\t\tif field.disabled\n\t\t\tfs.autoform.disabled = true\n\n\t\tif field.inlineHelpText\n\t\t\tfs.autoform.inlineHelpText = field.inlineHelpText\n\n\t\tif field.blackbox\n\t\t\tfs.blackbox = true\n\n\t\tif _.has(field, 'min')\n\t\t\tfs.min = field.min\n\t\tif _.has(field, 'max')\n\t\t\tfs.max = field.max\n\n\t\t# 只有生产环境才重建索引\n\t\tif Meteor.isProduction\n\t\t\tif field.index\n\t\t\t\tfs.index = field.index\n\t\t\telse if field.sortable\n\t\t\t\tfs.index = true\n\n\t\tschema[field_name] = fs\n\n\treturn schema\n\n\nCreator.getFieldDisplayValue = (object_name, field_name, field_value)->\n\thtml = field_value\n\tobject = Creator.getObject(object_name)\n\tif !object\n\t\treturn \"\"\n\tfield = object.fields(field_name)\n\tif !field\n\t\treturn \"\"\n\n\tif field.type == \"datetime\"\n\t\thtml = moment(this.val).format('YYYY-MM-DD H:mm')\n\telse if field.type == \"date\"\n\t\thtml = moment(this.val).format('YYYY-MM-DD')\n\n\treturn html\n\nCreator.checkFieldTypeSupportBetweenQuery = (field_type)->\n\treturn [\"date\", \"datetime\", \"time\", \"currency\", \"number\"].includes(field_type)\n\nCreator.pushBetweenBuiltinOptionals = (field_type, operations)->\n\tbuiltinValues = Creator.getBetweenBuiltinValues(field_type)\n\tif builtinValues\n\t\t_.forEach builtinValues, (builtinItem, key)->\n\t\t\toperations.push({label: builtinItem.label, value: key})\n\nCreator.getBetweenBuiltinValues = (field_type, is_check_only)->\n\t# 过滤器字段类型对应的内置选项\n\tif [\"date\", \"datetime\"].includes(field_type)\n\t\treturn Creator.getBetweenTimeBuiltinValues(is_check_only, field_type)\n\nCreator.getBetweenBuiltinValueItem = (field_type, key)->\n\t# 过滤器字段类型对应的内置选项\n\tif [\"date\", \"datetime\"].includes(field_type)\n\t\treturn Creator.getBetweenTimeBuiltinValueItem(field_type, key)\n\nCreator.getBetweenBuiltinOperation = (field_type, value)->\n\t# 根据过滤器的过滤值，获取对应的内置运算符\n\t# 比如value为last_year，返回between_time_last_year\n\tunless _.isString(value)\n\t\treturn\n\tbetweenBuiltinValues = Creator.getBetweenBuiltinValues(field_type)\n\tunless betweenBuiltinValues\n\t\treturn\n\tresult = null\n\t_.each betweenBuiltinValues, (item, operation)->\n\t\tif item.key == value\n\t\t\tresult = operation\n\treturn result\n\n# 如果只是为判断operation是否存在，则没必要计算values，传入is_check_only为true即可\nCreator.getBetweenTimeBuiltinValues = (is_check_only, field_type)->\n\t# 过滤器时间字段类型对应的内置选项\n\treturn {\n\t\t\"between_time_last_year\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_year\"),\n\t\t\"between_time_this_year\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_year\"),\n\t\t\"between_time_next_year\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_year\"),\n\t\t\"between_time_last_quarter\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_quarter\"),\n\t\t\"between_time_this_quarter\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_quarter\"),\n\t\t\"between_time_next_quarter\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_quarter\"),\n\t\t\"between_time_last_month\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_month\"),\n\t\t\"between_time_this_month\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_month\"),\n\t\t\"between_time_next_month\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_month\"),\n\t\t\"between_time_last_week\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_week\"),\n\t\t\"between_time_this_week\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_week\"),\n\t\t\"between_time_next_week\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_week\"),\n\t\t\"between_time_yestday\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"yestday\"),\n\t\t\"between_time_today\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"today\"),\n\t\t\"between_time_tomorrow\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"tomorrow\"),\n\t\t\"between_time_last_7_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_7_days\"),\n\t\t\"between_time_last_30_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_30_days\"),\n\t\t\"between_time_last_60_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_60_days\"),\n\t\t\"between_time_last_90_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_90_days\"),\n\t\t\"between_time_last_120_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_120_days\"),\n\t\t\"between_time_next_7_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_7_days\"),\n\t\t\"between_time_next_30_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_30_days\"),\n\t\t\"between_time_next_60_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_60_days\"),\n\t\t\"between_time_next_90_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_90_days\"),\n\t\t\"between_time_next_120_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_120_days\")\n\t}\n\nCreator.getQuarterStartMonth = (month)->\n\tif !month\n\t\tmonth = new Date().getMonth()\n\t\n\tif month < 3\n\t\treturn 0\n\telse if month < 6\n\t\treturn 3\n\telse if month < 9\n\t\treturn 6\n\t\n\treturn 9\n\n\nCreator.getLastQuarterFirstDay = (year,month)->\n\tif !year\n\t\tyear = new Date().getFullYear()\n\tif !month\n\t\tmonth = new Date().getMonth()\n\t\n\tif month < 3\n\t\tyear--\n\t\tmonth = 9\n\telse if month < 6\n\t\tmonth = 0\n\telse if month < 9\n\t\tmonth = 3\n\telse \n\t\tmonth = 6\n\t\n\treturn new Date(year, month, 1)\n\t\n\nCreator.getNextQuarterFirstDay = (year,month)->\n\tif !year\n\t\tyear = new Date().getFullYear()\n\tif !month\n\t\tmonth = new Date().getMonth()\n\t\n\tif month < 3\n\t\tmonth = 3\n\telse if month < 6\n\t\tmonth = 6\n\telse if month < 9\n\t\tmonth = 9\n\telse\n\t\tyear++\n\t\tmonth = 0\n\t\n\treturn new Date(year, month, 1)\n\nCreator.getMonthDays = (year,month)->\n\tif month == 11\n\t\treturn 31\n\t\n\tmillisecond = 1000 * 60 * 60 * 24\n\tstartDate = new Date(year, month, 1)\n\tendDate = new Date(year, month+1, 1)\n\tdays = (endDate-startDate)/millisecond\n\treturn days\n\nCreator.getLastMonthFirstDay = (year, month)->\n\tif !year\n\t\tyear = new Date().getFullYear()\n\tif !month\n\t\tmonth = new Date().getMonth()\n\t\n\t# 月份为0代表本年的第一月\n\tif month == 0\n\t\tmonth = 11\n\t\tyear--\n\t\treturn new Date(year, month, 1)\n\t\n\t# 否则,只减去月份\n\tmonth--;\n\treturn new Date(year, month, 1)\n\t\nCreator.getBetweenTimeBuiltinValueItem = (field_type, key)->\n\t# 过滤器between运算符，现算日期/日期时间类型字段的values值\n\tnow = new Date()\n\t# 一天的毫秒数\n\tmillisecond = 1000 * 60 * 60 * 24\n\tyestday = new Date(now.getTime() - millisecond)\n\ttomorrow = new Date(now.getTime() + millisecond)\n\t# 一周中的某一天\n\tweek = now.getDay()\n\t# 减去的天数\n\tminusDay = if week != 0 then week - 1 else 6\n\tmonday = new Date(now.getTime() - (minusDay * millisecond))\n\tsunday = new Date(monday.getTime() + (6 * millisecond))\n\t# 上周日\n\tlastSunday = new Date(monday.getTime() - millisecond)\n\t# 上周一\n\tlastMonday = new Date(lastSunday.getTime() - (millisecond * 6))\n\t# 下周一\n\tnextMonday = new Date(sunday.getTime() + millisecond)\n\t# 下周日\n\tnextSunday = new Date(nextMonday.getTime() + (millisecond * 6))\n\tcurrentYear = now.getFullYear()\n\tpreviousYear = currentYear - 1\n\tnextYear = currentYear + 1\n\t# 当前月份\n\tcurrentMonth = now.getMonth()\n\t# 计数年、月\n\tyear = now.getFullYear()\n\tmonth = now.getMonth()\n\t# 本月第一天\n\tfirstDay = new Date(currentYear,currentMonth,1)\n\n\t# 当为12月的时候年份需要加1\n\t# 月份需要更新为0 也就是下一年的第一个月\n\tif currentMonth == 11\n\t\tyear++\n\t\tmonth++\n\telse\n\t\tmonth++\n\t\n\t# 下月第一天\n\tnextMonthFirstDay = new Date(year, month, 1)\n\t# 下月最后一天\n\tnextMonthFinalDay = new Date(year,month,Creator.getMonthDays(year,month))\n\t# 本月最后一天\n\tlastDay = new Date(nextMonthFirstDay.getTime() - millisecond)\n\t# 上月第一天\n\tlastMonthFirstDay = Creator.getLastMonthFirstDay(currentYear,currentMonth)\n\t# 上月最后一天\n\tlastMonthFinalDay = new Date(firstDay.getTime() - millisecond)\n\t# 本季度开始日\n\tthisQuarterStartDay = new Date(currentYear,Creator.getQuarterStartMonth(currentMonth),1)\n\t# 本季度结束日\n\tthisQuarterEndDay = new Date(currentYear,Creator.getQuarterStartMonth(currentMonth)+2,Creator.getMonthDays(currentYear,Creator.getQuarterStartMonth(currentMonth)+2))\n\t# 上季度开始日\n\tlastQuarterStartDay = Creator.getLastQuarterFirstDay(currentYear,currentMonth)\n\t# 上季度结束日\n\tlastQuarterEndDay = new Date(lastQuarterStartDay.getFullYear(),lastQuarterStartDay.getMonth()+2,Creator.getMonthDays(lastQuarterStartDay.getFullYear(),lastQuarterStartDay.getMonth()+2))\n\t# 下季度开始日\n\tnextQuarterStartDay = Creator.getNextQuarterFirstDay(currentYear,currentMonth)\n\t# 下季度结束日\n\tnextQuarterEndDay = new Date(nextQuarterStartDay.getFullYear(),nextQuarterStartDay.getMonth()+2,Creator.getMonthDays(nextQuarterStartDay.getFullYear(),nextQuarterStartDay.getMonth()+2))\n\t# 过去7天 \n\tlast_7_days = new Date(now.getTime() - (6 * millisecond))\n\t# 过去30天\n\tlast_30_days = new Date(now.getTime() - (29 * millisecond))\n\t# 过去60天\n\tlast_60_days = new Date(now.getTime() - (59 * millisecond))\n\t# 过去90天\n\tlast_90_days = new Date(now.getTime() - (89 * millisecond))\n\t# 过去120天\n\tlast_120_days = new Date(now.getTime() - (119 * millisecond))\n\t# 未来7天 \n\tnext_7_days = new Date(now.getTime() + (6 * millisecond))\n\t# 未来30天\n\tnext_30_days = new Date(now.getTime() + (29 * millisecond))\n\t# 未来60天\n\tnext_60_days = new Date(now.getTime() + (59 * millisecond))\n\t# 未来90天\n\tnext_90_days = new Date(now.getTime() + (89 * millisecond))\n\t# 未来120天\n\tnext_120_days = new Date(now.getTime() + (119 * millisecond))\n\n\tswitch key\n\t\twhen \"last_year\"\n\t\t\t#去年\n\t\t\tlabel = t(\"creator_filter_operation_between_last_year\")\n\t\t\tstartValue = new Date(\"#{previousYear}-01-01T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{previousYear}-12-31T23:59:59Z\")\n\t\twhen \"this_year\"\n\t\t\t#今年\n\t\t\tlabel = t(\"creator_filter_operation_between_this_year\")\n\t\t\tstartValue = new Date(\"#{currentYear}-01-01T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{currentYear}-12-31T23:59:59Z\")\n\t\twhen \"next_year\"\n\t\t\t#明年\n\t\t\tlabel = t(\"creator_filter_operation_between_next_year\")\n\t\t\tstartValue = new Date(\"#{nextYear}-01-01T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{nextYear}-12-31T23:59:59Z\")\n\t\twhen \"last_quarter\"\n\t\t\t#上季度\n\t\t\tstrFirstDay = moment(lastQuarterStartDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(lastQuarterEndDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_quarter\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"this_quarter\"\n\t\t\t#本季度\n\t\t\tstrFirstDay = moment(thisQuarterStartDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(thisQuarterEndDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_this_quarter\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"next_quarter\"\n\t\t\t#下季度\n\t\t\tstrFirstDay = moment(nextQuarterStartDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(nextQuarterEndDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_quarter\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"last_month\"\n\t\t\t#上月\n\t\t\tstrFirstDay = moment(lastMonthFirstDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(lastMonthFinalDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_month\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"this_month\"\n\t\t\t#本月\n\t\t\tstrFirstDay = moment(firstDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(lastDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_this_month\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"next_month\"\n\t\t\t#下月\n\t\t\tstrFirstDay = moment(nextMonthFirstDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(nextMonthFinalDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_month\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"last_week\"\n\t\t\t#上周\n\t\t\tstrMonday = moment(lastMonday).format(\"YYYY-MM-DD\")\n\t\t\tstrSunday = moment(lastSunday).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_week\")\n\t\t\tstartValue = new Date(\"#{strMonday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strSunday}T23:59:59Z\")\n\t\twhen \"this_week\"\n\t\t\t#本周\n\t\t\tstrMonday = moment(monday).format(\"YYYY-MM-DD\")\n\t\t\tstrSunday = moment(sunday).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_this_week\")\n\t\t\tstartValue = new Date(\"#{strMonday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strSunday}T23:59:59Z\")\n\t\twhen \"next_week\"\n\t\t\t#下周\n\t\t\tstrMonday = moment(nextMonday).format(\"YYYY-MM-DD\")\n\t\t\tstrSunday = moment(nextSunday).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_week\")\n\t\t\tstartValue = new Date(\"#{strMonday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strSunday}T23:59:59Z\")\n\t\twhen \"yestday\"\n\t\t\t#昨天\n\t\t\tstrYestday = moment(yestday).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_yestday\")\n\t\t\tstartValue = new Date(\"#{strYestday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strYestday}T23:59:59Z\")\n\t\twhen \"today\"\n\t\t\t#今天\n\t\t\tstrToday = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_today\")\n\t\t\tstartValue = new Date(\"#{strToday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strToday}T23:59:59Z\")\n\t\twhen \"tomorrow\"\n\t\t\t#明天\n\t\t\tstrTomorrow = moment(tomorrow).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_tomorrow\")\n\t\t\tstartValue = new Date(\"#{strTomorrow}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strTomorrow}T23:59:59Z\")\n\t\twhen \"last_7_days\"\n\t\t\t#过去7天\n\t\t\tstrStartDay = moment(last_7_days).format(\"YYYY-MM-DD\") \n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_7_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"last_30_days\"\n\t\t\t#过去30天\n\t\t\tstrStartDay = moment(last_30_days).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_30_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"last_60_days\"\n\t\t\t#过去60天\n\t\t\tstrStartDay = moment(last_60_days).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_60_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"last_90_days\"\n\t\t\t#过去90天\n\t\t\tstrStartDay = moment(last_90_days).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_90_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"last_120_days\"\n\t\t\t#过去120天\n\t\t\tstrStartDay = moment(last_120_days).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_120_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_7_days\"\n\t\t\t#未来7天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_7_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_7_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_30_days\"\n\t\t\t#未来30天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_30_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_30_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_60_days\"\n\t\t\t#未来60天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_60_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_60_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_90_days\"\n\t\t\t#未来90天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_90_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_90_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_120_days\"\n\t\t\t#未来120天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_120_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_120_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\n\tvalues = [startValue, endValue]\n\tif field_type == \"datetime\"\n\t\t# 时间类型字段，内置时间范围应该考虑偏移时区值，否则过滤数据存在偏差\n\t\t# 非内置时间范围时，用户通过时间控件选择的范围，会自动处理时区偏差情况\n\t\t# 日期类型字段，数据库本来就存的是UTC的0点，不存在偏差\n\t\t_.forEach values, (fv)->\n\t\t\tif fv\n\t\t\t\tfv.setHours(fv.getHours() + fv.getTimezoneOffset() / 60 )\n\t\n\treturn {\n\t\tlabel: label\n\t\tkey: key\n\t\tvalues: values\n\t}\n\nCreator.getFieldDefaultOperation = (field_type)->\n\tif field_type && Creator.checkFieldTypeSupportBetweenQuery(field_type)\n\t\treturn 'between'\n\telse if [\"textarea\", \"text\", \"code\"].includes(field_type)\n\t\treturn 'contains'\n\telse\n\t\treturn \"=\"\n\nCreator.getFieldOperation = (field_type) ->\n\t# 日期类型: date, datetime  支持操作符: \"=\", \"<>\", \"<\", \">\", \"<=\", \">=\"\n\t# 文本类型: text, textarea, html  支持操作符: \"=\", \"<>\", \"contains\", \"notcontains\", \"startswith\"\n\t# 选择类型: lookup, master_detail, select 支持操作符: \"=\", \"<>\"\n\t# 数值类型: currency, number  支持操作符: \"=\", \"<>\", \"<\", \">\", \"<=\", \">=\"\n\t# 布尔类型: boolean  支持操作符: \"=\", \"<>\"\n\t# 数组类型: checkbox, [text]  支持操作符: \"=\", \"<>\"\n\n\toptionals = {\n\t\tequal: {label: t(\"creator_filter_operation_equal\"), value: \"=\"},\n\t\tunequal: {label: t(\"creator_filter_operation_unequal\"), value: \"<>\"},\n\t\tless_than: {label: t(\"creator_filter_operation_less_than\"), value: \"<\"},\n\t\tgreater_than: {label: t(\"creator_filter_operation_greater_than\"), value: \">\"},\n\t\tless_or_equal: {label: t(\"creator_filter_operation_less_or_equal\"), value: \"<=\"},\n\t\tgreater_or_equal: {label: t(\"creator_filter_operation_greater_or_equal\"), value: \">=\"},\n\t\tcontains: {label: t(\"creator_filter_operation_contains\"), value: \"contains\"},\n\t\tnot_contain: {label: t(\"creator_filter_operation_does_not_contain\"), value: \"notcontains\"},\n\t\tstarts_with: {label: t(\"creator_filter_operation_starts_with\"), value: \"startswith\"},\n\t\tbetween: {label: t(\"creator_filter_operation_between\"), value: \"between\"},\n\t}\n\n\tif field_type == undefined\n\t\treturn _.values(optionals)\n\n\toperations = []\n\n\tif Creator.checkFieldTypeSupportBetweenQuery(field_type)\n\t\toperations.push(optionals.between)\n\t\tCreator.pushBetweenBuiltinOptionals(field_type, operations)\n\telse if field_type == \"text\" or field_type == \"textarea\" or field_type == \"html\" or field_type == \"code\"\n#\t\toperations.push(optionals.equal, optionals.unequal, optionals.contains, optionals.not_contain, optionals.starts_with)\n\t\toperations.push(optionals.contains)\n\telse if field_type == \"lookup\" or field_type == \"master_detail\" or field_type == \"select\"\n\t\toperations.push(optionals.equal, optionals.unequal)\n\telse if field_type == \"currency\" or field_type == \"number\"\n\t\toperations.push(optionals.equal, optionals.unequal, optionals.less_than, optionals.greater_than, optionals.less_or_equal, optionals.greater_or_equal)\n\telse if field_type == \"boolean\"\n\t\toperations.push(optionals.equal, optionals.unequal)\n\telse if field_type == \"checkbox\"\n\t\toperations.push(optionals.equal, optionals.unequal)\n\telse if field_type == \"[text]\"\n\t\toperations.push(optionals.equal, optionals.unequal)\n\telse\n\t\toperations.push(optionals.equal, optionals.unequal)\n\n\treturn operations\n\n###\n    先按照有排序号的小的在前，大的在后\n    再将没有排序号的显示在\n###\nCreator.getObjectFieldsName = (object_name)->\n\tfields = Creator.getObject(object_name)?.fields\n\tfieldsArr = []\n\n\t_.each fields, (field)->\n\t\tfieldsArr.push {name: field.name, sort_no: field.sort_no}\n\n\tfieldsName = []\n\t_.each _.sortBy(fieldsArr, \"sort_no\"), (field)->\n\t\tfieldsName.push(field.name)\n\treturn fieldsName\n","Creator.getSelectOptions = function(fieldSchema) {\n  var data_type, options;\n  options = fieldSchema.options;\n  if (!options) {\n    return;\n  }\n  data_type = fieldSchema.data_type;\n  if (!_.isFunction(options) && data_type && data_type !== 'text') {\n    options.forEach(function(optionItem) {\n      if (typeof optionItem.value !== 'string') {\n        return;\n      }\n      if (['number', 'currency', 'percent'].indexOf(data_type) > -1) {\n        return optionItem.value = Number(optionItem.value);\n      } else if (data_type === 'boolean') {\n        return optionItem.value = optionItem.value === 'true';\n      }\n    });\n  }\n  return options;\n};\n\nCreator.getObjectSchema = function(obj) {\n  var fieldsArr, schema;\n  if (!obj) {\n    return;\n  }\n  schema = {};\n  fieldsArr = [];\n  _.each(obj.fields, function(field, field_name) {\n    if (!_.has(field, \"name\")) {\n      field.name = field_name;\n    }\n    return fieldsArr.push(field);\n  });\n  _.each(_.sortBy(fieldsArr, \"sort_no\"), function(field) {\n    var _object, _ref_obj, _reference_to, autoform_type, collectionName, field_name, fs, fsType, isUnLimited, permissions, ref, ref1;\n    field_name = field.name;\n    fs = {};\n    if (field.regEx) {\n      fs.regEx = field.regEx;\n    }\n    fs.autoform = {};\n    fs.autoform.multiple = field.multiple;\n    fs.autoform.reference_to = field.reference_to;\n    autoform_type = (ref = field.autoform) != null ? ref.type : void 0;\n    if (field.type === \"text\" || field.type === \"phone\") {\n      fs.type = String;\n      if (field.multiple) {\n        fs.type = [String];\n        fs.autoform.type = \"tags\";\n      }\n    } else if (field.type === \"[text]\" || field.type === \"[phone]\") {\n      fs.type = [String];\n      fs.autoform.type = \"tags\";\n    } else if (field.type === 'code') {\n      fs.type = String;\n      fs.autoform.type = \"widearea\";\n      fs.autoform.rows = field.rows || 12;\n      if (field.language) {\n        fs.autoform.language = field.language;\n      }\n    } else if (field.type === \"textarea\") {\n      fs.type = String;\n      fs.autoform.type = \"widearea\";\n      fs.autoform.rows = field.rows || 2;\n    } else if (field.type === \"password\") {\n      fs.type = String;\n      fs.autoform.type = \"password\";\n    } else if (field.type === \"date\") {\n      fs.type = Date;\n      if (Meteor.isClient) {\n        if (Steedos.isMobile() || Steedos.isPad()) {\n          if (Steedos.isiOS()) {\n            fs.autoform.afFieldInput = {\n              type: \"dx-date-box\",\n              timezoneId: \"utc\",\n              dxDateBoxOptions: {\n                type: \"date\",\n                displayFormat: \"yyyy-MM-dd\",\n                pickerType: \"rollers\"\n              }\n            };\n          } else {\n            fs.autoform.afFieldInput = {\n              type: \"steedos-date-mobile\",\n              dateMobileOptions: {\n                type: \"date\"\n              }\n            };\n          }\n        } else {\n          fs.autoform.outFormat = 'yyyy-MM-dd';\n          fs.autoform.afFieldInput = {\n            type: \"dx-date-box\",\n            timezoneId: \"utc\",\n            dxDateBoxOptions: {\n              type: \"date\",\n              displayFormat: \"yyyy-MM-dd\"\n            }\n          };\n        }\n      }\n    } else if (field.type === \"time\") {\n      fs.type = Date;\n      if (Meteor.isClient) {\n        fs.autoform.afFieldInput = {\n          type: \"dx-date-box\",\n          timezoneId: \"utc\",\n          dxDateBoxOptions: {\n            type: \"time\",\n            displayFormat: \"HH:mm\"\n          }\n        };\n      }\n    } else if (field.type === \"datetime\") {\n      fs.type = Date;\n      if (Meteor.isClient) {\n        if (Steedos.isMobile() || Steedos.isPad()) {\n          if (Steedos.isiOS()) {\n            fs.autoform.afFieldInput = {\n              type: \"dx-date-box\",\n              dxDateBoxOptions: {\n                type: \"datetime\",\n                displayFormat: \"yyyy-MM-dd HH:mm\",\n                pickerType: \"rollers\"\n              }\n            };\n          } else {\n            fs.autoform.afFieldInput = {\n              type: \"steedos-date-mobile\",\n              dateMobileOptions: {\n                type: \"datetime\"\n              }\n            };\n          }\n        } else {\n          fs.autoform.afFieldInput = {\n            type: \"dx-date-box\",\n            dxDateBoxOptions: {\n              type: \"datetime\",\n              displayFormat: \"yyyy-MM-dd HH:mm\"\n            }\n          };\n        }\n      }\n    } else if (field.type === \"[Object]\") {\n      fs.type = [Object];\n    } else if (field.type === \"html\") {\n      fs.type = String;\n      if (Meteor.isClient) {\n        fs.autoform.type = 'steedosHtml';\n      }\n    } else if (field.type === \"lookup\" || field.type === \"master_detail\") {\n      fs.type = String;\n      fs.autoform.showIcon = field.showIcon;\n      if (field.multiple) {\n        fs.type = [String];\n      }\n      if (!field.hidden) {\n        fs.autoform.filters = field.filters;\n        fs.autoform.dependOn = field.depend_on;\n        if (field.beforeOpenFunction) {\n          fs.beforeOpenFunction = field.beforeOpenFunction;\n        }\n        fs.filtersFunction = field.filtersFunction ? field.filtersFunction : Creator.evaluateFilters;\n        if (field.optionsFunction) {\n          fs.optionsFunction = field.optionsFunction;\n        }\n        if (field.reference_to) {\n          if (Meteor.isClient) {\n            if (field.createFunction && _.isFunction(field.createFunction)) {\n              fs.createFunction = field.createFunction;\n            } else {\n              if (_.isString(field.reference_to)) {\n                _ref_obj = Creator.Objects[field.reference_to];\n                if (_ref_obj != null ? (ref1 = _ref_obj.permissions) != null ? ref1.allowCreate : void 0 : void 0) {\n                  fs.autoform.create = true;\n                  fs.createFunction = function(lookup_field) {\n                    return Modal.show(\"CreatorObjectModal\", {\n                      collection: \"Creator.Collections.\" + (Creator.getCollection(field.reference_to)._name),\n                      formId: \"new\" + (field.reference_to.replace('.', '_')),\n                      object_name: \"\" + field.reference_to,\n                      operation: \"insert\",\n                      onSuccess: function(operation, result) {\n                        var object;\n                        object = Creator.getObject(result.object_name);\n                        if (result.object_name === \"objects\") {\n                          return lookup_field.addItems([\n                            {\n                              label: result.value.label,\n                              value: result.value.name,\n                              icon: result.value.icon\n                            }\n                          ], result.value.name);\n                        } else {\n                          return lookup_field.addItems([\n                            {\n                              label: result.value[object.NAME_FIELD_KEY] || result.value.label || result.value.name,\n                              value: result._id\n                            }\n                          ], result._id);\n                        }\n                      }\n                    });\n                  };\n                } else {\n                  fs.autoform.create = false;\n                }\n              }\n            }\n          }\n          if (_.isBoolean(field.create)) {\n            fs.autoform.create = field.create;\n          }\n          if (field.reference_sort) {\n            fs.autoform.optionsSort = field.reference_sort;\n          }\n          if (field.reference_limit) {\n            fs.autoform.optionsLimit = field.reference_limit;\n          }\n          if (field.reference_to_field) {\n            fs.autoform.referenceToField = field.reference_to_field;\n          }\n          if (field.reference_to === \"users\") {\n            fs.autoform.type = \"selectuser\";\n            if (!field.hidden && !field.omit) {\n              if (field.is_company_limited === void 0) {\n                if (Meteor.isClient) {\n                  permissions = obj.permissions;\n                  isUnLimited = permissions != null ? permissions.viewAllRecords : void 0;\n                  if (_.include([\"organizations\", \"users\", \"space_users\"], obj.name)) {\n                    isUnLimited = permissions != null ? permissions.modifyAllRecords : void 0;\n                  }\n                  if (isUnLimited) {\n                    fs.autoform.is_company_limited = false;\n                  } else {\n                    fs.autoform.is_company_limited = true;\n                  }\n                }\n              } else if (_.isFunction(field.is_company_limited)) {\n                if (Meteor.isClient) {\n                  fs.autoform.is_company_limited = field.is_company_limited(obj.permissions);\n                } else {\n                  fs.autoform.is_company_limited = true;\n                }\n              } else {\n                fs.autoform.is_company_limited = field.is_company_limited;\n              }\n            } else {\n              fs.autoform.is_company_limited = field.is_company_limited;\n            }\n          } else if (field.reference_to === \"organizations\") {\n            fs.autoform.type = \"selectorg\";\n            if (!field.hidden && !field.omit) {\n              if (field.is_company_limited === void 0) {\n                if (Meteor.isClient) {\n                  permissions = obj.permissions;\n                  isUnLimited = permissions != null ? permissions.viewAllRecords : void 0;\n                  if (_.include([\"organizations\", \"users\", \"space_users\"], obj.name)) {\n                    isUnLimited = permissions != null ? permissions.modifyAllRecords : void 0;\n                  }\n                  if (isUnLimited) {\n                    fs.autoform.is_company_limited = false;\n                  } else {\n                    fs.autoform.is_company_limited = true;\n                  }\n                }\n              } else if (_.isFunction(field.is_company_limited)) {\n                if (Meteor.isClient) {\n                  fs.autoform.is_company_limited = field.is_company_limited(obj.permissions);\n                } else {\n                  fs.autoform.is_company_limited = true;\n                }\n              } else {\n                fs.autoform.is_company_limited = field.is_company_limited;\n              }\n            } else {\n              fs.autoform.is_company_limited = field.is_company_limited;\n            }\n          } else {\n            if (typeof field.reference_to === \"function\") {\n              _reference_to = field.reference_to();\n            } else {\n              _reference_to = field.reference_to;\n            }\n            if (_.isArray(_reference_to)) {\n              fs.type = Object;\n              fs.blackbox = true;\n              fs.autoform.objectSwitche = true;\n              schema[field_name + \".o\"] = {\n                type: String,\n                autoform: {\n                  omit: true\n                }\n              };\n              schema[field_name + \".ids\"] = {\n                type: [String],\n                autoform: {\n                  omit: true\n                }\n              };\n            } else {\n              _reference_to = [_reference_to];\n            }\n            _object = Creator.Objects[_reference_to[0]];\n            if (_object && _object.enable_tree) {\n              fs.autoform.type = \"selectTree\";\n            } else {\n              fs.autoform.type = \"steedosLookups\";\n              fs.autoform.optionsMethod = field.optionsMethod || \"creator.object_options\";\n              if (Meteor.isClient) {\n                fs.autoform.optionsMethodParams = function() {\n                  return {\n                    space: Session.get(\"spaceId\")\n                  };\n                };\n                fs.autoform.references = [];\n                _reference_to.forEach(function(_reference) {\n                  _object = Creator.Objects[_reference];\n                  if (_object) {\n                    return fs.autoform.references.push({\n                      object: _reference,\n                      label: _object != null ? _object.label : void 0,\n                      icon: _object != null ? _object.icon : void 0,\n                      link: function() {\n                        return \"/app/\" + (Session.get('app_id')) + \"/\" + _reference + \"/view/\";\n                      }\n                    });\n                  } else {\n                    return fs.autoform.references.push({\n                      object: _reference,\n                      link: function() {\n                        return \"/app/\" + (Session.get('app_id')) + \"/\" + _reference + \"/view/\";\n                      }\n                    });\n                  }\n                });\n              }\n            }\n          }\n        } else {\n          fs.autoform.type = \"steedosLookups\";\n          fs.autoform.defaultIcon = field.defaultIcon;\n        }\n      }\n    } else if (field.type === \"select\") {\n      fs.type = String;\n      if (field.multiple) {\n        fs.type = [String];\n        fs.autoform.type = \"steedosLookups\";\n        fs.autoform.showIcon = false;\n        fs.autoform.options = field.options;\n      } else {\n        fs.autoform.type = \"select\";\n        fs.autoform.options = field.options;\n        if (_.has(field, 'firstOption')) {\n          fs.autoform.firstOption = field.firstOption;\n        } else {\n          fs.autoform.firstOption = \"\";\n        }\n      }\n      if (field.data_type && field.data_type !== \"text\") {\n        if ([\"number\", \"currency\", \"percent\"].indexOf(field.data_type) > -1) {\n          fsType = Number;\n          fs.decimal = true;\n        } else if (field.data_type === \"boolean\") {\n          fsType = Boolean;\n        } else {\n          fsType = String;\n        }\n        fs.type = fsType;\n        if (field.multiple) {\n          fs.type = [fsType];\n        }\n        fs.autoform.options = Creator.getSelectOptions(field);\n      }\n    } else if (field.type === \"currency\") {\n      fs.type = Number;\n      fs.autoform.type = \"steedosNumber\";\n      fs.autoform.precision = field.precision || 18;\n      if (field != null ? field.scale : void 0) {\n        fs.autoform.scale = field.scale;\n        fs.decimal = true;\n      } else if ((field != null ? field.scale : void 0) !== 0) {\n        fs.autoform.scale = 2;\n        fs.decimal = true;\n      }\n    } else if (field.type === \"number\") {\n      fs.type = Number;\n      fs.autoform.type = \"steedosNumber\";\n      fs.autoform.precision = field.precision || 18;\n      if (field != null ? field.scale : void 0) {\n        fs.autoform.scale = field.scale;\n        fs.decimal = true;\n      }\n    } else if (field.type === \"boolean\") {\n      fs.type = Boolean;\n      if (field.readonly) {\n        fs.autoform.disabled = true;\n      }\n      fs.autoform.type = \"steedos-boolean-checkbox\";\n    } else if (field.type === \"toggle\") {\n      fs.type = Boolean;\n      if (field.readonly) {\n        fs.autoform.disabled = true;\n      }\n      fs.autoform.type = \"steedos-boolean-toggle\";\n    } else if (field.type === \"reference\") {\n      fs.type = String;\n    } else if (field.type === \"checkbox\") {\n      fs.type = [String];\n      fs.autoform.type = \"select-checkbox\";\n      fs.autoform.options = field.options;\n    } else if (field.type === \"file\") {\n      collectionName = field.collection || \"files\";\n      if (field.multiple) {\n        fs.type = [String];\n        schema[field_name + \".$\"] = {\n          autoform: {\n            type: 'fileUpload',\n            collection: collectionName\n          }\n        };\n      } else {\n        fs.type = String;\n        fs.autoform.type = 'fileUpload';\n        fs.autoform.collection = collectionName;\n      }\n    } else if (field.type === \"filesize\") {\n      fs.type = Number;\n      fs.autoform.type = 'filesize';\n    } else if (field.type === \"Object\" || field.type === \"object\") {\n      fs.type = Object;\n    } else if (field.type === \"grid\" || field.type === \"table\") {\n      fs.type = Array;\n      fs.autoform.editable = true;\n      fs.autoform.type = \"steedosGrid\";\n      schema[field_name + \".$\"] = {\n        type: Object\n      };\n    } else if (field.type === \"image\") {\n      if (field.multiple) {\n        fs.type = [String];\n        schema[field_name + \".$\"] = {\n          autoform: {\n            type: 'fileUpload',\n            collection: 'images',\n            accept: 'image/*'\n          }\n        };\n      } else {\n        fs.type = String;\n        fs.autoform.type = 'fileUpload';\n        fs.autoform.collection = 'images';\n        fs.autoform.accept = 'image/*';\n      }\n    } else if (field.type === \"avatar\") {\n      if (field.multiple) {\n        fs.type = [String];\n        schema[field_name + \".$\"] = {\n          autoform: {\n            type: 'fileUpload',\n            collection: 'avatars',\n            accept: 'image/*'\n          }\n        };\n      } else {\n        fs.type = String;\n        fs.autoform.type = 'fileUpload';\n        fs.autoform.collection = 'avatars';\n        fs.autoform.accept = 'image/*';\n      }\n    } else if (field.type === \"audio\") {\n      if (field.multiple) {\n        fs.type = [String];\n        schema[field_name + \".$\"] = {\n          autoform: {\n            type: 'fileUpload',\n            collection: 'audios',\n            accept: 'audio/*'\n          }\n        };\n      } else {\n        fs.type = String;\n        fs.autoform.type = 'fileUpload';\n        fs.autoform.collection = 'audios';\n        fs.autoform.accept = 'audio/*';\n      }\n    } else if (field.type === \"video\") {\n      if (field.multiple) {\n        fs.type = [String];\n        schema[field_name + \".$\"] = {\n          autoform: {\n            type: 'fileUpload',\n            collection: 'videos',\n            accept: 'video/*'\n          }\n        };\n      } else {\n        fs.type = String;\n        fs.autoform.type = 'fileUpload';\n        fs.autoform.collection = 'videos';\n        fs.autoform.accept = 'video/*';\n      }\n    } else if (field.type === \"location\") {\n      fs.type = Object;\n      fs.autoform.type = \"location\";\n      fs.autoform.system = field.system || \"wgs84\";\n      fs.blackbox = true;\n    } else if (field.type === \"markdown\") {\n      fs.type = String;\n      fs.autoform.type = \"text\";\n    } else if (field.type === 'url') {\n      fs.type = String;\n      fs.autoform.type = 'steedosUrl';\n    } else if (field.type === 'email') {\n      fs.type = String;\n      fs.regEx = SimpleSchema.RegEx.Email;\n      fs.autoform.type = 'steedosEmail';\n    } else if (field.type === 'autonumber') {\n      fs.type = String;\n    } else if (field.type === 'color') {\n      fs.type = String;\n    } else if (field.type === 'formula') {\n      fs = Creator.getObjectSchema({\n        fields: {\n          field: Object.assign({}, field, {\n            type: field.data_type\n          })\n        }\n      })[field.name];\n    } else if (field.type === 'summary') {\n      fs = Creator.getObjectSchema({\n        fields: {\n          field: Object.assign({}, field, {\n            type: field.data_type\n          })\n        }\n      })[field.name];\n    } else if (field.type === 'percent') {\n      fs.type = Number;\n      fs.autoform.type = \"steedosNumber\";\n      fs.autoform.precision = field.precision || 18;\n      if (!_.isNumber(field.scale)) {\n        field.scale = 0;\n      }\n      fs.autoform.scale = field.scale + 2;\n      fs.decimal = true;\n    } else {\n      fs.type = field.type;\n    }\n    if (field.label) {\n      fs.label = field.label;\n    }\n    if (!field.required) {\n      fs.optional = true;\n    }\n    if (!Meteor.isClient) {\n      fs.optional = true;\n    }\n    if (field.unique) {\n      fs.unique = true;\n    }\n    if (field.omit) {\n      fs.autoform.omit = true;\n    }\n    if (field.group) {\n      fs.autoform.group = field.group;\n    }\n    if (field.is_wide) {\n      fs.autoform.is_wide = true;\n    }\n    if (field.hidden) {\n      fs.autoform.type = \"hidden\";\n    }\n    if ((field.type === \"select\") || (field.type === \"lookup\") || (field.type === \"master_detail\")) {\n      if (typeof field.filterable === 'undefined') {\n        field.filterable = true;\n      }\n    }\n    if (field.name === 'name' || field.is_name) {\n      if (typeof field.searchable === 'undefined') {\n        field.searchable = true;\n      }\n    }\n    if (autoform_type) {\n      fs.autoform.type = autoform_type;\n    }\n    if (field.defaultValue) {\n      if (Meteor.isClient && Creator.Formular.checkFormula(field.defaultValue)) {\n        fs.autoform.defaultValue = function() {\n          return Creator.Formular.run(field.defaultValue, {\n            userId: Meteor.userId(),\n            spaceId: Session.get(\"spaceId\"),\n            now: new Date()\n          });\n        };\n      } else {\n        fs.autoform.defaultValue = field.defaultValue;\n      }\n    }\n    if (field.readonly) {\n      fs.autoform.readonly = true;\n    }\n    if (field.disabled) {\n      fs.autoform.disabled = true;\n    }\n    if (field.inlineHelpText) {\n      fs.autoform.inlineHelpText = field.inlineHelpText;\n    }\n    if (field.blackbox) {\n      fs.blackbox = true;\n    }\n    if (_.has(field, 'min')) {\n      fs.min = field.min;\n    }\n    if (_.has(field, 'max')) {\n      fs.max = field.max;\n    }\n    if (Meteor.isProduction) {\n      if (field.index) {\n        fs.index = field.index;\n      } else if (field.sortable) {\n        fs.index = true;\n      }\n    }\n    return schema[field_name] = fs;\n  });\n  return schema;\n};\n\nCreator.getFieldDisplayValue = function(object_name, field_name, field_value) {\n  var field, html, object;\n  html = field_value;\n  object = Creator.getObject(object_name);\n  if (!object) {\n    return \"\";\n  }\n  field = object.fields(field_name);\n  if (!field) {\n    return \"\";\n  }\n  if (field.type === \"datetime\") {\n    html = moment(this.val).format('YYYY-MM-DD H:mm');\n  } else if (field.type === \"date\") {\n    html = moment(this.val).format('YYYY-MM-DD');\n  }\n  return html;\n};\n\nCreator.checkFieldTypeSupportBetweenQuery = function(field_type) {\n  return [\"date\", \"datetime\", \"time\", \"currency\", \"number\"].includes(field_type);\n};\n\nCreator.pushBetweenBuiltinOptionals = function(field_type, operations) {\n  var builtinValues;\n  builtinValues = Creator.getBetweenBuiltinValues(field_type);\n  if (builtinValues) {\n    return _.forEach(builtinValues, function(builtinItem, key) {\n      return operations.push({\n        label: builtinItem.label,\n        value: key\n      });\n    });\n  }\n};\n\nCreator.getBetweenBuiltinValues = function(field_type, is_check_only) {\n  if ([\"date\", \"datetime\"].includes(field_type)) {\n    return Creator.getBetweenTimeBuiltinValues(is_check_only, field_type);\n  }\n};\n\nCreator.getBetweenBuiltinValueItem = function(field_type, key) {\n  if ([\"date\", \"datetime\"].includes(field_type)) {\n    return Creator.getBetweenTimeBuiltinValueItem(field_type, key);\n  }\n};\n\nCreator.getBetweenBuiltinOperation = function(field_type, value) {\n  var betweenBuiltinValues, result;\n  if (!_.isString(value)) {\n    return;\n  }\n  betweenBuiltinValues = Creator.getBetweenBuiltinValues(field_type);\n  if (!betweenBuiltinValues) {\n    return;\n  }\n  result = null;\n  _.each(betweenBuiltinValues, function(item, operation) {\n    if (item.key === value) {\n      return result = operation;\n    }\n  });\n  return result;\n};\n\nCreator.getBetweenTimeBuiltinValues = function(is_check_only, field_type) {\n  return {\n    \"between_time_last_year\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_year\"),\n    \"between_time_this_year\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_year\"),\n    \"between_time_next_year\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_year\"),\n    \"between_time_last_quarter\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_quarter\"),\n    \"between_time_this_quarter\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_quarter\"),\n    \"between_time_next_quarter\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_quarter\"),\n    \"between_time_last_month\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_month\"),\n    \"between_time_this_month\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_month\"),\n    \"between_time_next_month\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_month\"),\n    \"between_time_last_week\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_week\"),\n    \"between_time_this_week\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_week\"),\n    \"between_time_next_week\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_week\"),\n    \"between_time_yestday\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"yestday\"),\n    \"between_time_today\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"today\"),\n    \"between_time_tomorrow\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"tomorrow\"),\n    \"between_time_last_7_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_7_days\"),\n    \"between_time_last_30_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_30_days\"),\n    \"between_time_last_60_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_60_days\"),\n    \"between_time_last_90_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_90_days\"),\n    \"between_time_last_120_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_120_days\"),\n    \"between_time_next_7_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_7_days\"),\n    \"between_time_next_30_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_30_days\"),\n    \"between_time_next_60_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_60_days\"),\n    \"between_time_next_90_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_90_days\"),\n    \"between_time_next_120_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_120_days\")\n  };\n};\n\nCreator.getQuarterStartMonth = function(month) {\n  if (!month) {\n    month = new Date().getMonth();\n  }\n  if (month < 3) {\n    return 0;\n  } else if (month < 6) {\n    return 3;\n  } else if (month < 9) {\n    return 6;\n  }\n  return 9;\n};\n\nCreator.getLastQuarterFirstDay = function(year, month) {\n  if (!year) {\n    year = new Date().getFullYear();\n  }\n  if (!month) {\n    month = new Date().getMonth();\n  }\n  if (month < 3) {\n    year--;\n    month = 9;\n  } else if (month < 6) {\n    month = 0;\n  } else if (month < 9) {\n    month = 3;\n  } else {\n    month = 6;\n  }\n  return new Date(year, month, 1);\n};\n\nCreator.getNextQuarterFirstDay = function(year, month) {\n  if (!year) {\n    year = new Date().getFullYear();\n  }\n  if (!month) {\n    month = new Date().getMonth();\n  }\n  if (month < 3) {\n    month = 3;\n  } else if (month < 6) {\n    month = 6;\n  } else if (month < 9) {\n    month = 9;\n  } else {\n    year++;\n    month = 0;\n  }\n  return new Date(year, month, 1);\n};\n\nCreator.getMonthDays = function(year, month) {\n  var days, endDate, millisecond, startDate;\n  if (month === 11) {\n    return 31;\n  }\n  millisecond = 1000 * 60 * 60 * 24;\n  startDate = new Date(year, month, 1);\n  endDate = new Date(year, month + 1, 1);\n  days = (endDate - startDate) / millisecond;\n  return days;\n};\n\nCreator.getLastMonthFirstDay = function(year, month) {\n  if (!year) {\n    year = new Date().getFullYear();\n  }\n  if (!month) {\n    month = new Date().getMonth();\n  }\n  if (month === 0) {\n    month = 11;\n    year--;\n    return new Date(year, month, 1);\n  }\n  month--;\n  return new Date(year, month, 1);\n};\n\nCreator.getBetweenTimeBuiltinValueItem = function(field_type, key) {\n  var currentMonth, currentYear, endValue, firstDay, label, lastDay, lastMonday, lastMonthFinalDay, lastMonthFirstDay, lastQuarterEndDay, lastQuarterStartDay, lastSunday, last_120_days, last_30_days, last_60_days, last_7_days, last_90_days, millisecond, minusDay, monday, month, nextMonday, nextMonthFinalDay, nextMonthFirstDay, nextQuarterEndDay, nextQuarterStartDay, nextSunday, nextYear, next_120_days, next_30_days, next_60_days, next_7_days, next_90_days, now, previousYear, startValue, strEndDay, strFirstDay, strLastDay, strMonday, strStartDay, strSunday, strToday, strTomorrow, strYestday, sunday, thisQuarterEndDay, thisQuarterStartDay, tomorrow, values, week, year, yestday;\n  now = new Date();\n  millisecond = 1000 * 60 * 60 * 24;\n  yestday = new Date(now.getTime() - millisecond);\n  tomorrow = new Date(now.getTime() + millisecond);\n  week = now.getDay();\n  minusDay = week !== 0 ? week - 1 : 6;\n  monday = new Date(now.getTime() - (minusDay * millisecond));\n  sunday = new Date(monday.getTime() + (6 * millisecond));\n  lastSunday = new Date(monday.getTime() - millisecond);\n  lastMonday = new Date(lastSunday.getTime() - (millisecond * 6));\n  nextMonday = new Date(sunday.getTime() + millisecond);\n  nextSunday = new Date(nextMonday.getTime() + (millisecond * 6));\n  currentYear = now.getFullYear();\n  previousYear = currentYear - 1;\n  nextYear = currentYear + 1;\n  currentMonth = now.getMonth();\n  year = now.getFullYear();\n  month = now.getMonth();\n  firstDay = new Date(currentYear, currentMonth, 1);\n  if (currentMonth === 11) {\n    year++;\n    month++;\n  } else {\n    month++;\n  }\n  nextMonthFirstDay = new Date(year, month, 1);\n  nextMonthFinalDay = new Date(year, month, Creator.getMonthDays(year, month));\n  lastDay = new Date(nextMonthFirstDay.getTime() - millisecond);\n  lastMonthFirstDay = Creator.getLastMonthFirstDay(currentYear, currentMonth);\n  lastMonthFinalDay = new Date(firstDay.getTime() - millisecond);\n  thisQuarterStartDay = new Date(currentYear, Creator.getQuarterStartMonth(currentMonth), 1);\n  thisQuarterEndDay = new Date(currentYear, Creator.getQuarterStartMonth(currentMonth) + 2, Creator.getMonthDays(currentYear, Creator.getQuarterStartMonth(currentMonth) + 2));\n  lastQuarterStartDay = Creator.getLastQuarterFirstDay(currentYear, currentMonth);\n  lastQuarterEndDay = new Date(lastQuarterStartDay.getFullYear(), lastQuarterStartDay.getMonth() + 2, Creator.getMonthDays(lastQuarterStartDay.getFullYear(), lastQuarterStartDay.getMonth() + 2));\n  nextQuarterStartDay = Creator.getNextQuarterFirstDay(currentYear, currentMonth);\n  nextQuarterEndDay = new Date(nextQuarterStartDay.getFullYear(), nextQuarterStartDay.getMonth() + 2, Creator.getMonthDays(nextQuarterStartDay.getFullYear(), nextQuarterStartDay.getMonth() + 2));\n  last_7_days = new Date(now.getTime() - (6 * millisecond));\n  last_30_days = new Date(now.getTime() - (29 * millisecond));\n  last_60_days = new Date(now.getTime() - (59 * millisecond));\n  last_90_days = new Date(now.getTime() - (89 * millisecond));\n  last_120_days = new Date(now.getTime() - (119 * millisecond));\n  next_7_days = new Date(now.getTime() + (6 * millisecond));\n  next_30_days = new Date(now.getTime() + (29 * millisecond));\n  next_60_days = new Date(now.getTime() + (59 * millisecond));\n  next_90_days = new Date(now.getTime() + (89 * millisecond));\n  next_120_days = new Date(now.getTime() + (119 * millisecond));\n  switch (key) {\n    case \"last_year\":\n      label = t(\"creator_filter_operation_between_last_year\");\n      startValue = new Date(previousYear + \"-01-01T00:00:00Z\");\n      endValue = new Date(previousYear + \"-12-31T23:59:59Z\");\n      break;\n    case \"this_year\":\n      label = t(\"creator_filter_operation_between_this_year\");\n      startValue = new Date(currentYear + \"-01-01T00:00:00Z\");\n      endValue = new Date(currentYear + \"-12-31T23:59:59Z\");\n      break;\n    case \"next_year\":\n      label = t(\"creator_filter_operation_between_next_year\");\n      startValue = new Date(nextYear + \"-01-01T00:00:00Z\");\n      endValue = new Date(nextYear + \"-12-31T23:59:59Z\");\n      break;\n    case \"last_quarter\":\n      strFirstDay = moment(lastQuarterStartDay).format(\"YYYY-MM-DD\");\n      strLastDay = moment(lastQuarterEndDay).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_last_quarter\");\n      startValue = new Date(strFirstDay + \"T00:00:00Z\");\n      endValue = new Date(strLastDay + \"T23:59:59Z\");\n      break;\n    case \"this_quarter\":\n      strFirstDay = moment(thisQuarterStartDay).format(\"YYYY-MM-DD\");\n      strLastDay = moment(thisQuarterEndDay).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_this_quarter\");\n      startValue = new Date(strFirstDay + \"T00:00:00Z\");\n      endValue = new Date(strLastDay + \"T23:59:59Z\");\n      break;\n    case \"next_quarter\":\n      strFirstDay = moment(nextQuarterStartDay).format(\"YYYY-MM-DD\");\n      strLastDay = moment(nextQuarterEndDay).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_next_quarter\");\n      startValue = new Date(strFirstDay + \"T00:00:00Z\");\n      endValue = new Date(strLastDay + \"T23:59:59Z\");\n      break;\n    case \"last_month\":\n      strFirstDay = moment(lastMonthFirstDay).format(\"YYYY-MM-DD\");\n      strLastDay = moment(lastMonthFinalDay).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_last_month\");\n      startValue = new Date(strFirstDay + \"T00:00:00Z\");\n      endValue = new Date(strLastDay + \"T23:59:59Z\");\n      break;\n    case \"this_month\":\n      strFirstDay = moment(firstDay).format(\"YYYY-MM-DD\");\n      strLastDay = moment(lastDay).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_this_month\");\n      startValue = new Date(strFirstDay + \"T00:00:00Z\");\n      endValue = new Date(strLastDay + \"T23:59:59Z\");\n      break;\n    case \"next_month\":\n      strFirstDay = moment(nextMonthFirstDay).format(\"YYYY-MM-DD\");\n      strLastDay = moment(nextMonthFinalDay).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_next_month\");\n      startValue = new Date(strFirstDay + \"T00:00:00Z\");\n      endValue = new Date(strLastDay + \"T23:59:59Z\");\n      break;\n    case \"last_week\":\n      strMonday = moment(lastMonday).format(\"YYYY-MM-DD\");\n      strSunday = moment(lastSunday).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_last_week\");\n      startValue = new Date(strMonday + \"T00:00:00Z\");\n      endValue = new Date(strSunday + \"T23:59:59Z\");\n      break;\n    case \"this_week\":\n      strMonday = moment(monday).format(\"YYYY-MM-DD\");\n      strSunday = moment(sunday).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_this_week\");\n      startValue = new Date(strMonday + \"T00:00:00Z\");\n      endValue = new Date(strSunday + \"T23:59:59Z\");\n      break;\n    case \"next_week\":\n      strMonday = moment(nextMonday).format(\"YYYY-MM-DD\");\n      strSunday = moment(nextSunday).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_next_week\");\n      startValue = new Date(strMonday + \"T00:00:00Z\");\n      endValue = new Date(strSunday + \"T23:59:59Z\");\n      break;\n    case \"yestday\":\n      strYestday = moment(yestday).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_yestday\");\n      startValue = new Date(strYestday + \"T00:00:00Z\");\n      endValue = new Date(strYestday + \"T23:59:59Z\");\n      break;\n    case \"today\":\n      strToday = moment(now).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_today\");\n      startValue = new Date(strToday + \"T00:00:00Z\");\n      endValue = new Date(strToday + \"T23:59:59Z\");\n      break;\n    case \"tomorrow\":\n      strTomorrow = moment(tomorrow).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_tomorrow\");\n      startValue = new Date(strTomorrow + \"T00:00:00Z\");\n      endValue = new Date(strTomorrow + \"T23:59:59Z\");\n      break;\n    case \"last_7_days\":\n      strStartDay = moment(last_7_days).format(\"YYYY-MM-DD\");\n      strEndDay = moment(now).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_last_7_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n      break;\n    case \"last_30_days\":\n      strStartDay = moment(last_30_days).format(\"YYYY-MM-DD\");\n      strEndDay = moment(now).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_last_30_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n      break;\n    case \"last_60_days\":\n      strStartDay = moment(last_60_days).format(\"YYYY-MM-DD\");\n      strEndDay = moment(now).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_last_60_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n      break;\n    case \"last_90_days\":\n      strStartDay = moment(last_90_days).format(\"YYYY-MM-DD\");\n      strEndDay = moment(now).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_last_90_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n      break;\n    case \"last_120_days\":\n      strStartDay = moment(last_120_days).format(\"YYYY-MM-DD\");\n      strEndDay = moment(now).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_last_120_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n      break;\n    case \"next_7_days\":\n      strStartDay = moment(now).format(\"YYYY-MM-DD\");\n      strEndDay = moment(next_7_days).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_next_7_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n      break;\n    case \"next_30_days\":\n      strStartDay = moment(now).format(\"YYYY-MM-DD\");\n      strEndDay = moment(next_30_days).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_next_30_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n      break;\n    case \"next_60_days\":\n      strStartDay = moment(now).format(\"YYYY-MM-DD\");\n      strEndDay = moment(next_60_days).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_next_60_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n      break;\n    case \"next_90_days\":\n      strStartDay = moment(now).format(\"YYYY-MM-DD\");\n      strEndDay = moment(next_90_days).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_next_90_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n      break;\n    case \"next_120_days\":\n      strStartDay = moment(now).format(\"YYYY-MM-DD\");\n      strEndDay = moment(next_120_days).format(\"YYYY-MM-DD\");\n      label = t(\"creator_filter_operation_between_next_120_days\");\n      startValue = new Date(strStartDay + \"T00:00:00Z\");\n      endValue = new Date(strEndDay + \"T23:59:59Z\");\n  }\n  values = [startValue, endValue];\n  if (field_type === \"datetime\") {\n    _.forEach(values, function(fv) {\n      if (fv) {\n        return fv.setHours(fv.getHours() + fv.getTimezoneOffset() / 60);\n      }\n    });\n  }\n  return {\n    label: label,\n    key: key,\n    values: values\n  };\n};\n\nCreator.getFieldDefaultOperation = function(field_type) {\n  if (field_type && Creator.checkFieldTypeSupportBetweenQuery(field_type)) {\n    return 'between';\n  } else if ([\"textarea\", \"text\", \"code\"].includes(field_type)) {\n    return 'contains';\n  } else {\n    return \"=\";\n  }\n};\n\nCreator.getFieldOperation = function(field_type) {\n  var operations, optionals;\n  optionals = {\n    equal: {\n      label: t(\"creator_filter_operation_equal\"),\n      value: \"=\"\n    },\n    unequal: {\n      label: t(\"creator_filter_operation_unequal\"),\n      value: \"<>\"\n    },\n    less_than: {\n      label: t(\"creator_filter_operation_less_than\"),\n      value: \"<\"\n    },\n    greater_than: {\n      label: t(\"creator_filter_operation_greater_than\"),\n      value: \">\"\n    },\n    less_or_equal: {\n      label: t(\"creator_filter_operation_less_or_equal\"),\n      value: \"<=\"\n    },\n    greater_or_equal: {\n      label: t(\"creator_filter_operation_greater_or_equal\"),\n      value: \">=\"\n    },\n    contains: {\n      label: t(\"creator_filter_operation_contains\"),\n      value: \"contains\"\n    },\n    not_contain: {\n      label: t(\"creator_filter_operation_does_not_contain\"),\n      value: \"notcontains\"\n    },\n    starts_with: {\n      label: t(\"creator_filter_operation_starts_with\"),\n      value: \"startswith\"\n    },\n    between: {\n      label: t(\"creator_filter_operation_between\"),\n      value: \"between\"\n    }\n  };\n  if (field_type === void 0) {\n    return _.values(optionals);\n  }\n  operations = [];\n  if (Creator.checkFieldTypeSupportBetweenQuery(field_type)) {\n    operations.push(optionals.between);\n    Creator.pushBetweenBuiltinOptionals(field_type, operations);\n  } else if (field_type === \"text\" || field_type === \"textarea\" || field_type === \"html\" || field_type === \"code\") {\n    operations.push(optionals.contains);\n  } else if (field_type === \"lookup\" || field_type === \"master_detail\" || field_type === \"select\") {\n    operations.push(optionals.equal, optionals.unequal);\n  } else if (field_type === \"currency\" || field_type === \"number\") {\n    operations.push(optionals.equal, optionals.unequal, optionals.less_than, optionals.greater_than, optionals.less_or_equal, optionals.greater_or_equal);\n  } else if (field_type === \"boolean\") {\n    operations.push(optionals.equal, optionals.unequal);\n  } else if (field_type === \"checkbox\") {\n    operations.push(optionals.equal, optionals.unequal);\n  } else if (field_type === \"[text]\") {\n    operations.push(optionals.equal, optionals.unequal);\n  } else {\n    operations.push(optionals.equal, optionals.unequal);\n  }\n  return operations;\n};\n\n\n/*\n    先按照有排序号的小的在前，大的在后\n    再将没有排序号的显示在\n */\n\nCreator.getObjectFieldsName = function(object_name) {\n  var fields, fieldsArr, fieldsName, ref;\n  fields = (ref = Creator.getObject(object_name)) != null ? ref.fields : void 0;\n  fieldsArr = [];\n  _.each(fields, function(field) {\n    return fieldsArr.push({\n      name: field.name,\n      sort_no: field.sort_no\n    });\n  });\n  fieldsName = [];\n  _.each(_.sortBy(fieldsArr, \"sort_no\"), function(field) {\n    return fieldsName.push(field.name);\n  });\n  return fieldsName;\n};\n","Creator._trigger_hooks = {}\n\ninitTrigger = (object_name, trigger)->\n\ttry\n\t\tcollection = Creator.getCollection(object_name)\n\t\tif !trigger.todo\n\t\t\treturn\n\t\ttodoWrapper = ()->\n\t\t\t  this.object_name = object_name\n\t\t\t  return trigger.todo.apply(this, arguments)\n\t\tif trigger.when == \"before.insert\"\n\t\t\t  return collection?.before?.insert(todoWrapper)\n\t\t  else if trigger.when == \"before.update\"\n\t\t\t  return collection?.before?.update(todoWrapper)\n\t\t  else if trigger.when == \"before.remove\"\n\t\t\t  return collection?.before?.remove(todoWrapper)\n\t\t  else if trigger.when == \"after.insert\"\n\t\t\t  return collection?.after?.insert(todoWrapper)\n\t\t  else if trigger.when == \"after.update\"\n\t\t\t  return collection?.after?.update(todoWrapper)\n\t\t  else if trigger.when == \"after.remove\"\n\t\t\t  return collection?.after?.remove(todoWrapper)\n\tcatch error\n\t\tconsole.error('initTrigger error', error)\n\ncleanTrigger = (object_name)->\n\t###\n    \t由于collection-hooks package 的remove函数是使用下标删除对象的，所以此处反转hooks集合后，再删除\n    \t因为一个数组元素删除后，其他元素的下标会发生变化\n\t###\n    #TODO 由于collection-hooks package 的remove函数bug\n\tCreator._trigger_hooks[object_name]?.reverse().forEach (_hook)->\n\t\t_hook.remove()\n\nCreator.initTriggers = (object_name)->\n#\tconsole.log('Creator.initTriggers object_name', object_name)\n\tobj = Creator.getObject(object_name)\n\n\tcleanTrigger(object_name)\n\n\tCreator._trigger_hooks[object_name] = []\n\n\t_.each obj.triggers, (trigger, trigger_name)->\n\t\tif Meteor.isServer and trigger.on == \"server\" and trigger.todo and trigger.when\n\t\t\t_trigger_hook = initTrigger object_name, trigger\n\t\t\tif _trigger_hook\n\t\t\t\tCreator._trigger_hooks[object_name].push(_trigger_hook)\n\t\tif Meteor.isClient and trigger.on == \"client\" and trigger.todo and trigger.when\n\t\t\t_trigger_hook = initTrigger object_name, trigger\n\t\t\tCreator._trigger_hooks[object_name].push(_trigger_hook)","var cleanTrigger, initTrigger;\n\nCreator._trigger_hooks = {};\n\ninitTrigger = function(object_name, trigger) {\n  var collection, error, ref, ref1, ref2, ref3, ref4, ref5, todoWrapper;\n  try {\n    collection = Creator.getCollection(object_name);\n    if (!trigger.todo) {\n      return;\n    }\n    todoWrapper = function() {\n      this.object_name = object_name;\n      return trigger.todo.apply(this, arguments);\n    };\n    if (trigger.when === \"before.insert\") {\n      return collection != null ? (ref = collection.before) != null ? ref.insert(todoWrapper) : void 0 : void 0;\n    } else if (trigger.when === \"before.update\") {\n      return collection != null ? (ref1 = collection.before) != null ? ref1.update(todoWrapper) : void 0 : void 0;\n    } else if (trigger.when === \"before.remove\") {\n      return collection != null ? (ref2 = collection.before) != null ? ref2.remove(todoWrapper) : void 0 : void 0;\n    } else if (trigger.when === \"after.insert\") {\n      return collection != null ? (ref3 = collection.after) != null ? ref3.insert(todoWrapper) : void 0 : void 0;\n    } else if (trigger.when === \"after.update\") {\n      return collection != null ? (ref4 = collection.after) != null ? ref4.update(todoWrapper) : void 0 : void 0;\n    } else if (trigger.when === \"after.remove\") {\n      return collection != null ? (ref5 = collection.after) != null ? ref5.remove(todoWrapper) : void 0 : void 0;\n    }\n  } catch (error1) {\n    error = error1;\n    return console.error('initTrigger error', error);\n  }\n};\n\ncleanTrigger = function(object_name) {\n\n  /*\n     \t由于collection-hooks package 的remove函数是使用下标删除对象的，所以此处反转hooks集合后，再删除\n     \t因为一个数组元素删除后，其他元素的下标会发生变化\n   */\n  var ref;\n  return (ref = Creator._trigger_hooks[object_name]) != null ? ref.reverse().forEach(function(_hook) {\n    return _hook.remove();\n  }) : void 0;\n};\n\nCreator.initTriggers = function(object_name) {\n  var obj;\n  obj = Creator.getObject(object_name);\n  cleanTrigger(object_name);\n  Creator._trigger_hooks[object_name] = [];\n  return _.each(obj.triggers, function(trigger, trigger_name) {\n    var _trigger_hook;\n    if (Meteor.isServer && trigger.on === \"server\" && trigger.todo && trigger.when) {\n      _trigger_hook = initTrigger(object_name, trigger);\n      if (_trigger_hook) {\n        Creator._trigger_hooks[object_name].push(_trigger_hook);\n      }\n    }\n    if (Meteor.isClient && trigger.on === \"client\" && trigger.todo && trigger.when) {\n      _trigger_hook = initTrigger(object_name, trigger);\n      return Creator._trigger_hooks[object_name].push(_trigger_hook);\n    }\n  });\n};\n","clone = require('clone')\n\nbaseBooleanPermissionPropNames = [\"allowCreate\", \"allowDelete\", \"allowEdit\", \"allowRead\", \"modifyAllRecords\", \"viewAllRecords\", \"modifyCompanyRecords\", \"viewCompanyRecords\", \n\t\"allowReadFiles\", \"allowEditFiles\", \"allowCreateFiles\", \"allowDeleteFiles\", \"viewAllFiles\", \"modifyAllFiles\"] \notherPermissionPropNames = [\"disabled_list_views\", \"disabled_actions\", \"unreadable_fields\", \"uneditable_fields\", \"unrelated_objects\", \"uneditable_related_list\"]\npermissionPropNames = _.union baseBooleanPermissionPropNames, otherPermissionPropNames\n\nCreator.getPermissions = (object_name, spaceId, userId)->\n\tif Meteor.isClient\n\t\tif !object_name\n\t\t\tobject_name = Session.get(\"object_name\")\n\t\tobj = Creator.getObject(object_name)\n\t\tif !obj\n\t\t\treturn\n\t\treturn obj.permissions.get()\n\telse if Meteor.isServer\n\t\tCreator.getObjectPermissions(spaceId, userId, object_name)\n\nCreator.getRecordPermissions = (object_name, record, userId, spaceId)->\n\tif !object_name and Meteor.isClient\n\t\tobject_name = Session.get(\"object_name\")\n\n\tif !spaceId and Meteor.isClient\n\t\tspaceId = Session.get(\"spaceId\")\n\t\n\t# 附件权限不再与其父记录编辑配置关联\n\t# if record and object_name == \"cms_files\" and Meteor.isClient\n\t# \t# 如果是cms_files附件，则权限取其父记录权限\n\t# \tif object_name == Session.get('object_name')\n\t# \t\t# 当前处于cms_files附件详细界面\n\t# \t\tobject_name = record.parent['reference_to._o'];\n\t# \t\trecord_id = record.parent._id;\n\t# \telse \n\t# \t\t# 当前处于cms_files附件的父记录界面\n\t# \t\tobject_name = Session.get('object_name');\n\t# \t\trecord_id = Session.get(\"record_id\");\n\t# \tobject_fields_keys = _.keys(Creator.getObject(object_name, spaceId)?.fields or {}) || [];\n\t# \tselect = _.intersection(object_fields_keys, ['owner', 'company_id', 'company_ids', 'locked']) || [];\n\t# \tif select.length > 0\n\t# \t\trecord = Creator.getObjectRecord(object_name, record_id, select.join(','));\n\t# \telse\n\t# \t\trecord = null;\n\n\tpermissions = _.clone(Creator.getPermissions(object_name, spaceId, userId))\n\n\tif record\n\t\tif !_.isEmpty(record.record_permissions)\n\t\t\treturn record.record_permissions\n\n\t\tisOwner = record.owner == userId || record.owner?._id == userId\n\n\t\tif object_name == \"cms_files\"\n\t\t\t# 附件的查看所有修改所有权限与附件对象的viewAllRecords、modifyAllRecords无关，只与其主表记录的viewAllFiles和modifyAllFiles有关\n\t\t\t# 如果是cms_files附件，则权限需要额外考虑其父对象上关于附件的权限配置\n\t\t\tmasterObjectName = record.parent['reference_to._o'];\n\t\t\tmasterRecordPerm = Creator.getPermissions(masterObjectName, spaceId, userId)\n\t\t\tpermissions.allowCreate = permissions.allowCreate && masterRecordPerm.allowCreateFiles\n\t\t\tpermissions.allowEdit = permissions.allowEdit && masterRecordPerm.allowEditFiles\n\t\t\tpermissions.allowDelete = permissions.allowDelete && masterRecordPerm.allowDeleteFiles\n\t\t\tif !masterRecordPerm.modifyAllFiles and !isOwner\n\t\t\t\tpermissions.allowEdit = false\n\t\t\t\tpermissions.allowDelete = false\n\t\t\tpermissions.allowRead = permissions.allowRead && masterRecordPerm.allowReadFiles\n\t\t\tif !masterRecordPerm.viewAllFiles and !isOwner\n\t\t\t\tpermissions.allowRead = false\n\t\telse\n\t\t\tif Meteor.isClient\n\t\t\t\tuser_company_ids = Steedos.getUserCompanyIds()\n\t\t\telse\n\t\t\t\tuser_company_ids = Creator.getUserCompanyIds(userId, spaceId)\n\t\t\trecord_company_id = record?.company_id\n\t\t\tif record_company_id and _.isObject(record_company_id) and record_company_id._id\n\t\t\t\t# 因record_company_id是lookup类型，有可能dx控件会把它映射转为对应的object，所以这里取出其_id值\n\t\t\t\trecord_company_id = record_company_id._id\n\t\t\trecord_company_ids = record?.company_ids\n\t\t\tif record_company_ids and record_company_ids.length and _.isObject(record_company_ids[0])\n\t\t\t\t# 因record_company_ids是lookup类型，有可能dx控件会把它映射转为对应的[object]，所以这里取出其_id值\n\t\t\t\trecord_company_ids = record_company_ids.map((n)-> n._id)\n\t\t\trecord_company_ids = _.union(record_company_ids, [record_company_id])\n\t\t\tif !permissions.modifyAllRecords and !isOwner and !permissions.modifyCompanyRecords\n\t\t\t\tpermissions.allowEdit = false\n\t\t\t\tpermissions.allowDelete = false\n\t\t\telse if !permissions.modifyAllRecords and permissions.modifyCompanyRecords\n\t\t\t\tif record_company_ids and record_company_ids.length\n\t\t\t\t\tif user_company_ids and user_company_ids.length\n\t\t\t\t\t\tif !_.intersection(user_company_ids, record_company_ids).length\n\t\t\t\t\t\t\t# 记录的company_id/company_ids属性不在当前用户user_company_ids范围内时，认为无权修改\n\t\t\t\t\t\t\tpermissions.allowEdit = false\n\t\t\t\t\t\t\tpermissions.allowDelete = false\n\t\t\t\t\telse\n\t\t\t\t\t\t# 记录有company_id/company_ids属性，但是当前用户user_company_ids为空时，认为无权修改\n\t\t\t\t\t\tpermissions.allowEdit = false\n\t\t\t\t\t\tpermissions.allowDelete = false\n\t\t\t\n\t\t\tif record.locked and !permissions.modifyAllRecords\n\t\t\t\tpermissions.allowEdit = false\n\t\t\t\tpermissions.allowDelete = false\n\n\t\t\tif !permissions.viewAllRecords and !isOwner and !permissions.viewCompanyRecords\n\t\t\t\tpermissions.allowRead = false\n\t\t\telse if !permissions.viewAllRecords and permissions.viewCompanyRecords\n\t\t\t\tif record_company_ids and record_company_ids.length\n\t\t\t\t\tif user_company_ids and user_company_ids.length\n\t\t\t\t\t\tif !_.intersection(user_company_ids, record_company_ids).length\n\t\t\t\t\t\t\t# 记录的company_id/company_ids属性不在当前用户user_company_ids范围内时，认为无权查看\n\t\t\t\t\t\t\tpermissions.allowRead = false\n\t\t\t\t\telse\n\t\t\t\t\t\t# 记录有company_id属性，但是当前用户user_company_ids为空时，认为无权查看\n\t\t\t\t\t\tpermissions.allowRead = false\n\t\n\treturn permissions\n\n\n# currentObjectName：当前主对象\n# relatedListItem：Creator.getRelatedList(Session.get(\"object_name\"), Session.get(\"record_id\"))中取related_object_name对应的值\n# currentRecord当前主对象的详细记录\nif Meteor.isClient\n\tCreator.getRecordRelatedListPermissions = (currentObjectName, relatedListItem, currentRecord, userId, spaceId)->\n\t\tif !currentObjectName and Meteor.isClient\n\t\t\tcurrentObjectName = Session.get(\"object_name\")\n\n\t\tif !relatedListItem\n\t\t\tconsole.error(\"relatedListItem must not be empty for the function Creator.getRecordRelatedListPermissions\");\n\t\t\treturn {}\n\n\t\tif !currentRecord and Meteor.isClient\n\t\t\tcurrentRecord = Creator.getObjectRecord()\n\n\t\tif !userId and Meteor.isClient\n\t\t\tuserId = Meteor.userId()\n\n\t\tif !spaceId and Meteor.isClient\n\t\t\tspaceId = Session.get(\"spaceId\")\n\n\t\tmasterRecordPerm = Creator.getRecordPermissions(currentObjectName, currentRecord, userId, spaceId)\n\t\trelatedObjectPermissions = Creator.getPermissions(relatedListItem.object_name)\n\t\tresult = _.clone relatedObjectPermissions\n\n\t\tif relatedListItem.is_file\n\t\t\tresult.allowCreate = relatedObjectPermissions.allowCreate && masterRecordPerm.allowCreateFiles\n\t\t\tresult.allowEdit = relatedObjectPermissions.allowEdit && masterRecordPerm.allowEditFiles\n\t\telse\n\t\t\twrite_requires_master_read = relatedListItem.write_requires_master_read || false\n\t\t\tmasterAllow = false\n\t\t\tif write_requires_master_read == true\n\t\t\t\tmasterAllow = masterRecordPerm.allowRead\n\t\t\telse if write_requires_master_read == false\n\t\t\t\tmasterAllow = masterRecordPerm.allowEdit\n\n\t\t\tuneditable_related_list = Creator.getRecordSafeRelatedList(currentRecord, currentObjectName)\n\t\t\tisRelateObjectUneditable = uneditable_related_list.indexOf(relatedListItem.object_name) > -1\n\n\t\t\tresult.allowCreate = masterAllow && relatedObjectPermissions.allowCreate && !isRelateObjectUneditable\n\t\t\tresult.allowEdit = masterAllow && relatedObjectPermissions.allowEdit && !isRelateObjectUneditable\n\t\treturn result\n\nif Meteor.isServer\n\n\tCreator.getAllPermissions = (spaceId, userId) ->\n\t\tpermissions =\n\t\t\tobjects: {}\n\t\t\tassigned_apps: []\n\t\t###\n\t\t权限集说明:\n\t\t内置权限集-admin,user,member,guest,workflow_admin,organization_admin\n\t\t自定义权限集-数据库中新建的除内置权限集以外的其他权限集\n\t\t特定用户集合权限集（即users属性不可配置）-admin,user,member,guest\n\t\t可配置用户集合权限集（即users属性可配置）-workflow_admin,organization_admin以及自定义权限集\n\t\t###\n\n\t\tisSpaceAdmin = false\n\t\tspaceUser = null\n\t\tif userId\n\t\t\tisSpaceAdmin = Creator.isSpaceAdmin(spaceId, userId)\n\t\t\tspaceUser = Creator.getCollection(\"space_users\").findOne({ space: spaceId, user: userId }, { fields: { profile: 1 } })\n\n\t\tpsetsAdmin = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'admin'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tpsetsUser = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'user'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tpsetsMember = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'member'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tpsetsGuest = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'guest'}, {fields:{_id:1, assigned_apps:1}}) || null\n\n\t\tpsetsSupplier = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'supplier'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tpsetsCustomer = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'customer'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tif spaceUser && spaceUser.profile\n\t\t\tpsetsCurrent = Creator.getCollection(\"permission_set\").find({space: spaceId, $or: [{users: userId}, {name: spaceUser.profile}]}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\telse\n\t\t\tpsetsCurrent = Creator.getCollection(\"permission_set\").find({users: userId, space: spaceId}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\n\t\tpsetsAdmin_pos = null\n\t\tpsetsUser_pos = null\n\t\tpsetsMember_pos = null\n\t\tpsetsGuest_pos = null\n\t\tpsetsCurrent_pos = null\n\t\tpsetsSupplier_pos = null\n\t\tpsetsCustomer_pos = null\n\n\t\tif psetsAdmin?._id\n\t\t\tpsetsAdmin_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsAdmin._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsUser?._id\n\t\t\tpsetsUser_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsUser._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsMember?._id\n\t\t\tpsetsMember_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsMember._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsGuest?._id\n\t\t\tpsetsGuest_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsGuest._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsSupplier?._id\n\t\t\tpsetsSupplier_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsSupplier._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsCustomer?._id\n\t\t\tpsetsCustomer_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsCustomer._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\n\t\tif psetsCurrent.length > 0\n\t\t\tset_ids = _.pluck psetsCurrent, \"_id\"\n\t\t\tpsetsCurrent_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: {$in: set_ids}}).fetch()\n\t\t\tpsetsCurrentNames = _.pluck psetsCurrent, \"name\"\n\t\tpsets = {\n\t\t\tpsetsAdmin, \n\t\t\tpsetsUser, \n\t\t\tpsetsCurrent, \n\t\t\tpsetsMember, \n\t\t\tpsetsGuest,\n\t\t\tpsetsSupplier,\n\t\t\tpsetsCustomer,\n\t\t\tisSpaceAdmin,\n\t\t\tspaceUser, \n\t\t\tpsetsAdmin_pos, \n\t\t\tpsetsUser_pos, \n\t\t\tpsetsMember_pos, \n\t\t\tpsetsGuest_pos,\n\t\t\tpsetsSupplier_pos,\n\t\t\tpsetsCustomer_pos,\n\t\t\tpsetsCurrent_pos\n\t\t}\n\t\tpermissions.assigned_apps = Creator.getAssignedApps.bind(psets)(spaceId, userId)\n\t\tpermissions.assigned_menus = Creator.getAssignedMenus.bind(psets)(spaceId, userId)\n\t\tpermissions.user_permission_sets = psetsCurrentNames\n\t\t_i = 0\n\t\t_.each Creator.objectsByName, (object, object_name)->\n\t\t\t_i++\n\t\t\tif !_.has(object, 'space') || !object.space || object.space == spaceId\n\t\t\t\tif !_.has(object, 'in_development') || object.in_development == '0' || (object.in_development != '0' && isSpaceAdmin)\n\t\t\t\t\tpermissions.objects[object_name] = Creator.convertObject(clone(Creator.Objects[object_name]), spaceId)\n\t\t\t\t\tpermissions.objects[object_name][\"permissions\"] = Creator.getObjectPermissions.bind(psets)(spaceId, userId, object_name)\n\t\treturn permissions\n\n\tunionPlus = (array, other) ->\n\t\tif !array and !other\n\t\t\treturn undefined\n\t\tif !array\n\t\t\tarray = []\n\t\tif !other\n\t\t\tother = []\n\t\treturn _.union(array, other)\n\n\tintersectionPlus = (array, other) ->\n\t\tif !array and !other\n\t\t\treturn undefined\n\t\tif !array\n\t\t\tarray = []\n\t\tif !other\n\t\t\tother = []\n\t\treturn _.intersection(array, other)\n\n\textendPermissionProps = (target, props) ->\n\t\tpropNames = permissionPropNames\n\t\tfilesProNames = \n\t\tif props\n\t\t\t_.each propNames, (propName) ->\n\t\t\t\ttarget[propName] = props[propName]\n\n\t\t\t# target.allowCreate = props.allowCreate\n\t\t\t# target.allowDelete = props.allowDelete\n\t\t\t# target.allowEdit = props.allowEdit\n\t\t\t# target.allowRead = props.allowRead\n\t\t\t# target.modifyAllRecords = props.modifyAllRecords\n\t\t\t# target.viewAllRecords = props.viewAllRecords\n\t\t\t# target.modifyCompanyRecords = props.modifyCompanyRecords\n\t\t\t# target.viewCompanyRecords = props.viewCompanyRecords\n\t\t\t# target.disabled_list_views = props.disabled_list_views\n\t\t\t# target.disabled_actions = props.disabled_actions\n\t\t\t# target.unreadable_fields = props.unreadable_fields\n\t\t\t# target.uneditable_fields = props.uneditable_fields\n\t\t\t# target.unrelated_objects = props.unrelated_objects\n\t\t\t# target.uneditable_related_list = props.uneditable_related_list\n\n\toverlayBaseBooleanPermissionProps = (target, props) ->\n\t\tpropNames = baseBooleanPermissionPropNames\n\t\t_.each propNames, (propName) ->\n\t\t\tif props[propName]\n\t\t\t\ttarget[propName] = true\n\t\t\n\t\t# if po.allowRead\n\t\t# \tpermissions.allowRead = true\n\t\t# if po.allowCreate\n\t\t# \tpermissions.allowCreate = true\n\t\t# if po.allowEdit\n\t\t# \tpermissions.allowEdit = true\n\t\t# if po.allowDelete\n\t\t# \tpermissions.allowDelete = true\n\t\t# if po.modifyAllRecords\n\t\t# \tpermissions.modifyAllRecords = true\n\t\t# if po.viewAllRecords\n\t\t# \tpermissions.viewAllRecords = true\n\t\t# if po.modifyCompanyRecords\n\t\t# \tpermissions.modifyCompanyRecords = true\n\t\t# if po.viewCompanyRecords\n\t\t# \tpermissions.viewCompanyRecords = true\n\n\n\tCreator.getAssignedApps = (spaceId, userId)->\n\t\tpsetsAdmin = this.psetsAdmin || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'admin'}, {fields:{_id:1, assigned_apps:1}})\n\t\tpsetsUser = this.psetsUser || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'user'}, {fields:{_id:1, assigned_apps:1}})\n\t\tpsetsSupplier = this.psetsMember || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'supplier'}, {fields:{_id:1, assigned_apps:1}})\n\t\tpsetsCustomer = this.psetsGuest || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'customer'}, {fields:{_id:1, assigned_apps:1}})\n\t\t# psetsMember = this.psetsMember || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'member'}, {fields:{_id:1, assigned_apps:1}})\n\t\t# psetsGuest = this.psetsGuest || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'guest'}, {fields:{_id:1, assigned_apps:1}})\n\t\tspaceUser = null;\n\t\tif userId\n\t\t\tspaceUser = Creator.getCollection(\"space_users\").findOne({ space: spaceId, user: userId }, { fields: { profile: 1 } })\n\t\tif spaceUser && spaceUser.profile\n\t\t\tpsets = Creator.getCollection(\"permission_set\").find({space: spaceId, $or: [{users: userId}, {name: spaceUser.profile}]}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\telse\n\t\t\tpsets = Creator.getCollection(\"permission_set\").find({users: userId, space: spaceId}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\tisSpaceAdmin = if _.isBoolean(this.isSpaceAdmin) then this.isSpaceAdmin else Creator.isSpaceAdmin(spaceId, userId)\n\t\tapps = []\n\t\tif isSpaceAdmin\n\t\t\treturn []\n\t\telse\n\t\t\tuserProfile = Creator.getCollection(\"space_users\").findOne({space: spaceId, user: userId}, {fields: {profile: 1}})?.profile\n\t\t\tpsetBase = psetsUser\n\t\t\tif userProfile\n\t\t\t\tif userProfile == 'supplier'\n\t\t\t\t\tpsetBase = psetsSupplier\n\t\t\t\telse if userProfile == 'customer'\n\t\t\t\t\tpsetBase = psetsCustomer\n\t\t\tif psetBase?.assigned_apps?.length\n\t\t\t\tapps = _.union apps, psetBase.assigned_apps\n\t\t\telse\n\t\t\t\t# user权限集中的assigned_apps表示所有用户具有的apps权限，为空则表示有所有apps权限，不需要作权限判断了\n\t\t\t\treturn []\n\t\t\t_.each psets, (pset)->\n\t\t\t\tif !pset.assigned_apps\n\t\t\t\t\treturn\n\t\t\t\tif pset.name == \"admin\" ||  pset.name == \"user\" || pset.name == 'supplier' || pset.name == 'customer'\n\t\t\t\t\t# 这里之所以要排除admin/user，是因为这两个权限集是所有权限集中users属性无效的权限集，特指工作区管理员和所有用户\n\t\t\t\t\treturn\n\t\t\t\tapps = _.union apps, pset.assigned_apps\n\t\t\treturn _.without(_.uniq(apps),undefined,null)\n\n\tCreator.getAssignedMenus = (spaceId, userId)->\n\t\tpsets =  this.psetsCurrent || Creator.getCollection(\"permission_set\").find({users: userId, space: spaceId}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\tisSpaceAdmin = if _.isBoolean(this.isSpaceAdmin) then this.isSpaceAdmin else Creator.isSpaceAdmin(spaceId, userId)\n\t\tadminMenus = Creator.Apps.admin?.admin_menus\n\t\t# 如果没有admin菜单说明不需要相关功能，直接返回空\n\t\tunless adminMenus\n\t\t\treturn []\n\t\taboutMenu = adminMenus.find (n) ->\n\t\t\tn._id == 'about'\n\t\tadminMenus = adminMenus.filter (n) ->\n\t\t\tn._id != 'about'\n\t\totherMenuApps = _.sortBy _.filter(_.values(Creator.Apps), (n) ->\n\t\t\treturn n.admin_menus and n._id != 'admin'\n\t\t), 'sort'\n\t\totherMenus = _.flatten(_.pluck(otherMenuApps, \"admin_menus\"))\n\t\t# 菜单有三部分组成，设置APP菜单、其他APP菜单以及about菜单\n\t\tallMenus = _.union(adminMenus, otherMenus, [aboutMenu])\n\t\tif isSpaceAdmin\n\t\t\t# 工作区管理员有全部菜单功能\n\t\t\tresult = allMenus\n\t\telse\n\t\t\tuserProfile = Creator.getCollection(\"space_users\").findOne({space: spaceId, user: userId}, {fields: {profile: 1}})?.profile || 'user'\n\t\t\tcurrentPsetNames = psets.map (n) ->\n\t\t\t\treturn n.name\n\t\t\tmenus = allMenus.filter (menu)->\n\t\t\t\tpsetsMenu = menu.permission_sets\n\t\t\t\t# 如果普通用户有权限，则直接返回true\n\t\t\t\tif psetsMenu && psetsMenu.indexOf(userProfile) > -1\n\t\t\t\t\treturn true\n\t\t\t\t# 否则取当前用户的权限集与menu菜单要求的权限集对比，如果交集大于1个则返回true\n\t\t\t\treturn _.intersection(currentPsetNames, psetsMenu).length\n\t\t\tresult = menus\n\t\t\n\t\treturn _.sortBy(result,\"sort\")\n\n\tfindOne_permission_object = (permission_objects, object_name, permission_set_id)->\n\n\t\tif _.isNull(permission_objects)\n\t\t\treturn null\n\t\tif _.isArray(permission_objects)\n\t\t\treturn _.find permission_objects, (po)->\n\t\t\t\t\treturn po.object_name == object_name\n\t\treturn Creator.getCollection(\"permission_objects\").findOne({object_name: object_name, permission_set_id: permission_set_id})\n\n\tfind_permission_object = (permission_objects, object_name, permission_set_ids)->\n\t\tif _.isNull(permission_objects)\n\t\t\treturn null\n\t\tif _.isArray(permission_objects)\n\t\t\treturn _.filter permission_objects, (po)->\n\t\t\t\treturn po.object_name == object_name\n\t\tCreator.getCollection(\"permission_objects\").find({object_name: object_name, permission_set_id: {$in: permission_set_ids}}).fetch()\n\n\tunionPermissionObjects = (pos, object, psets)->\n\t\t# 把db及yml中的permission_objects合并，优先取db中的\n\t\tresult = []\n\t\t_.each object.permission_set, (ops, ops_key)->\n\t\t\t# 把yml中除了特定用户集合权限集\"admin\", \"user\", \"member\", \"guest\"外的其他对象权限先存入result\n\t\t\t# if [\"admin\", \"user\", \"member\", \"guest\", \"workflow_admin\", \"organization_admin\"].indexOf(ops_key) < 0\n\t\t\tif [\"admin\", \"user\", \"member\", \"guest\"].indexOf(ops_key) < 0\n\t\t\t\tcurrentPset = psets.find (pset)-> return pset.name == ops_key\n\t\t\t\tif currentPset\n\t\t\t\t\ttempOps = _.clone(ops) || {}\n\t\t\t\t\ttempOps.permission_set_id = currentPset._id\n\t\t\t\t\ttempOps.object_name = object.object_name\n\t\t\t\t\tresult.push tempOps\n\t\tif result.length\n\t\t\tpos.forEach (po)->\n\t\t\t\trepeatIndex = 0\n\t\t\t\trepeatPo = result.find((item, index)-> repeatIndex = index;return item.permission_set_id == po.permission_set_id)\n\t\t\t\t# 如果yml中已经存在po，则替换为数据库中的po，反之则把数据库中的po直接累加进去\n\t\t\t\tif repeatPo\n\t\t\t\t\tresult[repeatIndex] = po\n\t\t\t\telse\n\t\t\t\t\tresult.push po\n\t\t\treturn result\n\t\telse\n\t\t\treturn pos\n\n\tCreator.getObjectPermissions = (spaceId, userId, object_name)->\n\t\tpermissions = {}\n\t\tobject = Creator.getObject(object_name, spaceId)\n\n\t\tif spaceId is 'guest' || object_name == \"users\"\n\t\t\tpermissions = _.clone(object.permission_set.guest) || {}\n\t\t\tCreator.processPermissions permissions\n\t\t\treturn permissions\n\t\tpsetsAdmin = if _.isNull(this.psetsAdmin) or this.psetsAdmin then this.psetsAdmin else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'admin'}, {fields:{_id:1}})\n\t\tpsetsUser = if _.isNull(this.psetsUser) or this.psetsUser then this.psetsUser else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'user'}, {fields:{_id:1}})\n\t\tpsetsMember = if _.isNull(this.psetsMember) or this.psetsMember then this.psetsMember else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'member'}, {fields:{_id:1}})\n\t\tpsetsGuest = if _.isNull(this.psetsGuest) or this.psetsGuest then this.psetsGuest else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'guest'}, {fields:{_id:1}})\n\n\t\tpsetsSupplier = if _.isNull(this.psetsSupplier) or this.psetsSupplier then this.psetsSupplier else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'supplier'}, {fields:{_id:1}})\n\t\tpsetsCustomer = if _.isNull(this.psetsCustomer) or this.psetsCustomer then this.psetsCustomer else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'customer'}, {fields:{_id:1}})\n\t\tpsets = this.psetsCurrent;\n\t\tif !psets\n\t\t\tspaceUser = null;\n\t\t\tif userId\n\t\t\t\tspaceUser = Creator.getCollection(\"space_users\").findOne({ space: spaceId, user: userId }, { fields: { profile: 1 } })\n\t\t\tif spaceUser && spaceUser.profile\n\t\t\t\tpsets = Creator.getCollection(\"permission_set\").find({space: spaceId, $or: [{users: userId}, {name: spaceUser.profile}]}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\t\telse\n\t\t\t\tpsets = Creator.getCollection(\"permission_set\").find({users: userId, space: spaceId}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\tisSpaceAdmin = if _.isBoolean(this.isSpaceAdmin) then this.isSpaceAdmin else Creator.isSpaceAdmin(spaceId, userId)\n\n\t\tpsetsAdmin_pos = this.psetsAdmin_pos\n\t\tpsetsUser_pos = this.psetsUser_pos\n\t\tpsetsMember_pos = this.psetsMember_pos\n\t\tpsetsGuest_pos = this.psetsGuest_pos\n\n\t\tpsetsSupplier_pos = this.psetsSupplier_pos\n\t\tpsetsCustomer_pos = this.psetsCustomer_pos\n\n\t\tpsetsCurrent_pos = this.psetsCurrent_pos\n\n\t\topsetAdmin = _.clone(object.permission_set.admin) || {}\n\t\topsetUser = _.clone(object.permission_set.user) || {}\n\t\topsetMember = _.clone(object.permission_set.member) || {}\n\t\topsetGuest = _.clone(object.permission_set.guest) || {}\n\n\t\topsetSupplier = _.clone(object.permission_set.supplier) || {}\n\t\topsetCustomer = _.clone(object.permission_set.customer) || {}\n\n\t\t# sharedListViews = Creator.getCollection('object_listviews').find({space: spaceId, object_name: object_name, shared: true}, {fields:{_id:1}}).fetch()\n\t\t# sharedListViews = _.pluck(sharedListViews,\"_id\")\n\t\t# if sharedListViews.length\n\t\t# \tunless opsetAdmin.list_views\n\t\t# \t\topsetAdmin.list_views = []\n\t\t# \topsetAdmin.list_views = _.union opsetAdmin.list_views, sharedListViews\n\t\t# \tunless opsetUser.list_views\n\t\t# \t\topsetUser.list_views = []\n\t\t# \topsetUser.list_views = _.union opsetUser.list_views, sharedListViews\n\t\t# 数据库中如果配置了默认的admin/user权限集设置，应该覆盖代码中admin/user的权限集设置\n\t\tif psetsAdmin\n\t\t\tposAdmin = findOne_permission_object(psetsAdmin_pos, object_name, psetsAdmin._id)\n\t\t\textendPermissionProps opsetAdmin, posAdmin\n\t\tif psetsUser\n\t\t\tposUser = findOne_permission_object(psetsUser_pos, object_name, psetsUser._id)\n\t\t\textendPermissionProps opsetUser, posUser\n\t\tif psetsMember\n\t\t\tposMember = findOne_permission_object(psetsMember_pos, object_name, psetsMember._id)\n\t\t\textendPermissionProps opsetMember, posMember\n\t\tif psetsGuest\n\t\t\tposGuest = findOne_permission_object(psetsGuest_pos, object_name, psetsGuest._id)\n\t\t\textendPermissionProps opsetGuest, posGuest\n\t\tif psetsSupplier\n\t\t\tposSupplier = findOne_permission_object(psetsSupplier_pos, object_name, psetsSupplier._id);\n\t\t\textendPermissionProps opsetSupplier, posSupplier\n\t\tif psetsCustomer\n\t\t\tposCustomer = findOne_permission_object(psetsCustomer_pos, object_name, psetsCustomer._id);\n\t\t\textendPermissionProps opsetCustomer, posCustomer\n\n\t\tif !userId\n\t\t\tpermissions = opsetAdmin\n\t\telse\n\t\t\tif isSpaceAdmin\n\t\t\t\tpermissions = opsetAdmin\n\t\t\telse\n\t\t\t\tif spaceId is 'common'\n\t\t\t\t\tpermissions = opsetUser\n\t\t\t\telse\n\t\t\t\t\tspaceUser = if _.isNull(this.spaceUser) or this.spaceUser then this.spaceUser else Creator.getCollection(\"space_users\").findOne({ space: spaceId, user: userId }, { fields: { profile: 1 } })\n\t\t\t\t\tif spaceUser\n\t\t\t\t\t\tprof = spaceUser.profile\n\t\t\t\t\t\tif prof\n\t\t\t\t\t\t\tif prof is 'user'\n\t\t\t\t\t\t\t\tpermissions = opsetUser\n\t\t\t\t\t\t\telse if prof is 'member'\n\t\t\t\t\t\t\t\tpermissions = opsetMember\n\t\t\t\t\t\t\telse if prof is 'guest'\n\t\t\t\t\t\t\t\tpermissions = opsetGuest\n\t\t\t\t\t\t\telse if prof is 'supplier'\n\t\t\t\t\t\t\t\tpermissions = opsetSupplier\n\t\t\t\t\t\t\telse if prof is 'customer'\n\t\t\t\t\t\t\t\tpermissions = opsetCustomer\n\t\t\t\t\t\telse # 没有profile则认为是user权限\n\t\t\t\t\t\t\tpermissions = opsetUser\n\t\t\t\t\telse\n\t\t\t\t\t\tpermissions = opsetGuest\n\t\tif psets.length > 0\n\t\t\tset_ids = _.pluck psets, \"_id\"\n\t\t\tpos = find_permission_object(psetsCurrent_pos, object_name, set_ids)\n\t\t\tpos = unionPermissionObjects(pos, object, psets)\n\t\t\t_.each pos, (po)->\n\t\t\t\tif po.permission_set_id == psetsAdmin?._id or \n\t\t\t\tpo.permission_set_id == psetsUser?._id or \n\t\t\t\tpo.permission_set_id == psetsMember?._id or \n\t\t\t\tpo.permission_set_id == psetsGuest?._id or\n\t\t\t\tpo.permission_set_id == psetsSupplier?._id or\n\t\t\t\tpo.permission_set_id == psetsCustomer?._id\n\t\t\t\t\t# 默认的admin/user权限值只实行上面的默认值覆盖，不做算法判断\n\t\t\t\t\treturn\n\t\t\t\tif _.isEmpty(permissions)\n\t\t\t\t\tpermissions = po\n\t\t\t\toverlayBaseBooleanPermissionProps permissions, po\n\n\t\t\t\tpermissions.disabled_list_views = intersectionPlus(permissions.disabled_list_views, po.disabled_list_views)\n\t\t\t\tpermissions.disabled_actions = intersectionPlus(permissions.disabled_actions, po.disabled_actions)\n\t\t\t\tpermissions.unreadable_fields = intersectionPlus(permissions.unreadable_fields, po.unreadable_fields)\n\t\t\t\tpermissions.uneditable_fields = intersectionPlus(permissions.uneditable_fields, po.uneditable_fields)\n\t\t\t\tpermissions.unrelated_objects = intersectionPlus(permissions.unrelated_objects, po.unrelated_objects)\n\t\t\t\tpermissions.uneditable_related_list = intersectionPlus(permissions.uneditable_related_list, po.uneditable_related_list)\n\t\t\n\t\tif object.is_view\n\t\t\tpermissions.allowCreate = false\n\t\t\tpermissions.allowEdit = false\n\t\t\tpermissions.allowDelete = false\n\t\t\tpermissions.modifyAllRecords = false\n\t\t\tpermissions.modifyCompanyRecords = false\n\t\t\tpermissions.disabled_actions = []\n\t\tCreator.processPermissions permissions\n\n\t\tif object.permission_set.owner\n\t\t\tpermissions.owner = object.permission_set.owner\n\t\treturn permissions\n\n\n\t# Creator.initPermissions = (object_name) ->\n\n\t\t# # 应该把计算出来的\n\t\t# Creator.Collections[object_name].allow\n\t\t# \tinsert: (userId, doc) ->\n\t\t# \t\tif !userId\n\t\t# \t\t\treturn false\n\t\t# \t\tif !doc.space\n\t\t# \t\t\treturn false\n\t    \t# \t\tpermissions = Creator.getObjectPermissions(doc.space, userId, object_name)\n\t\t# \t\tif !permissions.allowCreate\n\t\t# \t\t\treturn false\n\n\t\t# \t\treturn true\n\t\t# \tupdate: (userId, doc) ->\n\t\t# \t\tif !userId\n\t\t# \t\t\treturn false\n\t\t# \t\tif !doc.space\n\t\t# \t\t\treturn false\n\t\t# \t\tpermissions = Creator.getObjectPermissions(doc.space, userId, object_name)\n\t\t# \t\tif !permissions.allowEdit\n\t\t# \t\t\treturn false\n\t\t# \t\treturn true\n\t\t# \tremove: (userId, doc) ->\n\t\t# \t\tif !userId\n\t\t# \t\t\treturn false\n\t\t# \t\tif !doc.space\n\t\t# \t\t\treturn false\n\t\t# \t\tpermissions = Creator.getObjectPermissions(doc.space, userId, object_name)\n\t\t# \t\tif !permissions.allowDelete\n\t\t# \t\t\treturn false\n\t\t# \t\treturn true\n\n\tMeteor.methods\n\t\t# Calculate Permissions on Server\n\t\t\"creator.object_permissions\": (spaceId)->\n\t\t\treturn Creator.getAllPermissions(spaceId, this.userId)\n","var baseBooleanPermissionPropNames, clone, extendPermissionProps, findOne_permission_object, find_permission_object, intersectionPlus, otherPermissionPropNames, overlayBaseBooleanPermissionProps, permissionPropNames, unionPermissionObjects, unionPlus;\n\nclone = require('clone');\n\nbaseBooleanPermissionPropNames = [\"allowCreate\", \"allowDelete\", \"allowEdit\", \"allowRead\", \"modifyAllRecords\", \"viewAllRecords\", \"modifyCompanyRecords\", \"viewCompanyRecords\", \"allowReadFiles\", \"allowEditFiles\", \"allowCreateFiles\", \"allowDeleteFiles\", \"viewAllFiles\", \"modifyAllFiles\"];\n\notherPermissionPropNames = [\"disabled_list_views\", \"disabled_actions\", \"unreadable_fields\", \"uneditable_fields\", \"unrelated_objects\", \"uneditable_related_list\"];\n\npermissionPropNames = _.union(baseBooleanPermissionPropNames, otherPermissionPropNames);\n\nCreator.getPermissions = function(object_name, spaceId, userId) {\n  var obj;\n  if (Meteor.isClient) {\n    if (!object_name) {\n      object_name = Session.get(\"object_name\");\n    }\n    obj = Creator.getObject(object_name);\n    if (!obj) {\n      return;\n    }\n    return obj.permissions.get();\n  } else if (Meteor.isServer) {\n    return Creator.getObjectPermissions(spaceId, userId, object_name);\n  }\n};\n\nCreator.getRecordPermissions = function(object_name, record, userId, spaceId) {\n  var isOwner, masterObjectName, masterRecordPerm, permissions, record_company_id, record_company_ids, ref, user_company_ids;\n  if (!object_name && Meteor.isClient) {\n    object_name = Session.get(\"object_name\");\n  }\n  if (!spaceId && Meteor.isClient) {\n    spaceId = Session.get(\"spaceId\");\n  }\n  permissions = _.clone(Creator.getPermissions(object_name, spaceId, userId));\n  if (record) {\n    if (!_.isEmpty(record.record_permissions)) {\n      return record.record_permissions;\n    }\n    isOwner = record.owner === userId || ((ref = record.owner) != null ? ref._id : void 0) === userId;\n    if (object_name === \"cms_files\") {\n      masterObjectName = record.parent['reference_to._o'];\n      masterRecordPerm = Creator.getPermissions(masterObjectName, spaceId, userId);\n      permissions.allowCreate = permissions.allowCreate && masterRecordPerm.allowCreateFiles;\n      permissions.allowEdit = permissions.allowEdit && masterRecordPerm.allowEditFiles;\n      permissions.allowDelete = permissions.allowDelete && masterRecordPerm.allowDeleteFiles;\n      if (!masterRecordPerm.modifyAllFiles && !isOwner) {\n        permissions.allowEdit = false;\n        permissions.allowDelete = false;\n      }\n      permissions.allowRead = permissions.allowRead && masterRecordPerm.allowReadFiles;\n      if (!masterRecordPerm.viewAllFiles && !isOwner) {\n        permissions.allowRead = false;\n      }\n    } else {\n      if (Meteor.isClient) {\n        user_company_ids = Steedos.getUserCompanyIds();\n      } else {\n        user_company_ids = Creator.getUserCompanyIds(userId, spaceId);\n      }\n      record_company_id = record != null ? record.company_id : void 0;\n      if (record_company_id && _.isObject(record_company_id) && record_company_id._id) {\n        record_company_id = record_company_id._id;\n      }\n      record_company_ids = record != null ? record.company_ids : void 0;\n      if (record_company_ids && record_company_ids.length && _.isObject(record_company_ids[0])) {\n        record_company_ids = record_company_ids.map(function(n) {\n          return n._id;\n        });\n      }\n      record_company_ids = _.union(record_company_ids, [record_company_id]);\n      if (!permissions.modifyAllRecords && !isOwner && !permissions.modifyCompanyRecords) {\n        permissions.allowEdit = false;\n        permissions.allowDelete = false;\n      } else if (!permissions.modifyAllRecords && permissions.modifyCompanyRecords) {\n        if (record_company_ids && record_company_ids.length) {\n          if (user_company_ids && user_company_ids.length) {\n            if (!_.intersection(user_company_ids, record_company_ids).length) {\n              permissions.allowEdit = false;\n              permissions.allowDelete = false;\n            }\n          } else {\n            permissions.allowEdit = false;\n            permissions.allowDelete = false;\n          }\n        }\n      }\n      if (record.locked && !permissions.modifyAllRecords) {\n        permissions.allowEdit = false;\n        permissions.allowDelete = false;\n      }\n      if (!permissions.viewAllRecords && !isOwner && !permissions.viewCompanyRecords) {\n        permissions.allowRead = false;\n      } else if (!permissions.viewAllRecords && permissions.viewCompanyRecords) {\n        if (record_company_ids && record_company_ids.length) {\n          if (user_company_ids && user_company_ids.length) {\n            if (!_.intersection(user_company_ids, record_company_ids).length) {\n              permissions.allowRead = false;\n            }\n          } else {\n            permissions.allowRead = false;\n          }\n        }\n      }\n    }\n  }\n  return permissions;\n};\n\nif (Meteor.isClient) {\n  Creator.getRecordRelatedListPermissions = function(currentObjectName, relatedListItem, currentRecord, userId, spaceId) {\n    var isRelateObjectUneditable, masterAllow, masterRecordPerm, relatedObjectPermissions, result, uneditable_related_list, write_requires_master_read;\n    if (!currentObjectName && Meteor.isClient) {\n      currentObjectName = Session.get(\"object_name\");\n    }\n    if (!relatedListItem) {\n      console.error(\"relatedListItem must not be empty for the function Creator.getRecordRelatedListPermissions\");\n      return {};\n    }\n    if (!currentRecord && Meteor.isClient) {\n      currentRecord = Creator.getObjectRecord();\n    }\n    if (!userId && Meteor.isClient) {\n      userId = Meteor.userId();\n    }\n    if (!spaceId && Meteor.isClient) {\n      spaceId = Session.get(\"spaceId\");\n    }\n    masterRecordPerm = Creator.getRecordPermissions(currentObjectName, currentRecord, userId, spaceId);\n    relatedObjectPermissions = Creator.getPermissions(relatedListItem.object_name);\n    result = _.clone(relatedObjectPermissions);\n    if (relatedListItem.is_file) {\n      result.allowCreate = relatedObjectPermissions.allowCreate && masterRecordPerm.allowCreateFiles;\n      result.allowEdit = relatedObjectPermissions.allowEdit && masterRecordPerm.allowEditFiles;\n    } else {\n      write_requires_master_read = relatedListItem.write_requires_master_read || false;\n      masterAllow = false;\n      if (write_requires_master_read === true) {\n        masterAllow = masterRecordPerm.allowRead;\n      } else if (write_requires_master_read === false) {\n        masterAllow = masterRecordPerm.allowEdit;\n      }\n      uneditable_related_list = Creator.getRecordSafeRelatedList(currentRecord, currentObjectName);\n      isRelateObjectUneditable = uneditable_related_list.indexOf(relatedListItem.object_name) > -1;\n      result.allowCreate = masterAllow && relatedObjectPermissions.allowCreate && !isRelateObjectUneditable;\n      result.allowEdit = masterAllow && relatedObjectPermissions.allowEdit && !isRelateObjectUneditable;\n    }\n    return result;\n  };\n}\n\nif (Meteor.isServer) {\n  Creator.getAllPermissions = function(spaceId, userId) {\n    var _i, isSpaceAdmin, permissions, psets, psetsAdmin, psetsAdmin_pos, psetsCurrent, psetsCurrentNames, psetsCurrent_pos, psetsCustomer, psetsCustomer_pos, psetsGuest, psetsGuest_pos, psetsMember, psetsMember_pos, psetsSupplier, psetsSupplier_pos, psetsUser, psetsUser_pos, set_ids, spaceUser;\n    permissions = {\n      objects: {},\n      assigned_apps: []\n    };\n\n    /*\n    \t\t权限集说明:\n    \t\t内置权限集-admin,user,member,guest,workflow_admin,organization_admin\n    \t\t自定义权限集-数据库中新建的除内置权限集以外的其他权限集\n    \t\t特定用户集合权限集（即users属性不可配置）-admin,user,member,guest\n    \t\t可配置用户集合权限集（即users属性可配置）-workflow_admin,organization_admin以及自定义权限集\n     */\n    isSpaceAdmin = false;\n    spaceUser = null;\n    if (userId) {\n      isSpaceAdmin = Creator.isSpaceAdmin(spaceId, userId);\n      spaceUser = Creator.getCollection(\"space_users\").findOne({\n        space: spaceId,\n        user: userId\n      }, {\n        fields: {\n          profile: 1\n        }\n      });\n    }\n    psetsAdmin = Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'admin'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    }) || null;\n    psetsUser = Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'user'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    }) || null;\n    psetsMember = Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'member'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    }) || null;\n    psetsGuest = Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'guest'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    }) || null;\n    psetsSupplier = Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'supplier'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    }) || null;\n    psetsCustomer = Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'customer'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    }) || null;\n    if (spaceUser && spaceUser.profile) {\n      psetsCurrent = Creator.getCollection(\"permission_set\").find({\n        space: spaceId,\n        $or: [\n          {\n            users: userId\n          }, {\n            name: spaceUser.profile\n          }\n        ]\n      }, {\n        fields: {\n          _id: 1,\n          assigned_apps: 1,\n          name: 1\n        }\n      }).fetch();\n    } else {\n      psetsCurrent = Creator.getCollection(\"permission_set\").find({\n        users: userId,\n        space: spaceId\n      }, {\n        fields: {\n          _id: 1,\n          assigned_apps: 1,\n          name: 1\n        }\n      }).fetch();\n    }\n    psetsAdmin_pos = null;\n    psetsUser_pos = null;\n    psetsMember_pos = null;\n    psetsGuest_pos = null;\n    psetsCurrent_pos = null;\n    psetsSupplier_pos = null;\n    psetsCustomer_pos = null;\n    if (psetsAdmin != null ? psetsAdmin._id : void 0) {\n      psetsAdmin_pos = Creator.getCollection(\"permission_objects\").find({\n        permission_set_id: psetsAdmin._id\n      }, {\n        fields: {\n          created: 0,\n          modified: 0,\n          created_by: 0,\n          modified_by: 0\n        }\n      }).fetch();\n    }\n    if (psetsUser != null ? psetsUser._id : void 0) {\n      psetsUser_pos = Creator.getCollection(\"permission_objects\").find({\n        permission_set_id: psetsUser._id\n      }, {\n        fields: {\n          created: 0,\n          modified: 0,\n          created_by: 0,\n          modified_by: 0\n        }\n      }).fetch();\n    }\n    if (psetsMember != null ? psetsMember._id : void 0) {\n      psetsMember_pos = Creator.getCollection(\"permission_objects\").find({\n        permission_set_id: psetsMember._id\n      }, {\n        fields: {\n          created: 0,\n          modified: 0,\n          created_by: 0,\n          modified_by: 0\n        }\n      }).fetch();\n    }\n    if (psetsGuest != null ? psetsGuest._id : void 0) {\n      psetsGuest_pos = Creator.getCollection(\"permission_objects\").find({\n        permission_set_id: psetsGuest._id\n      }, {\n        fields: {\n          created: 0,\n          modified: 0,\n          created_by: 0,\n          modified_by: 0\n        }\n      }).fetch();\n    }\n    if (psetsSupplier != null ? psetsSupplier._id : void 0) {\n      psetsSupplier_pos = Creator.getCollection(\"permission_objects\").find({\n        permission_set_id: psetsSupplier._id\n      }, {\n        fields: {\n          created: 0,\n          modified: 0,\n          created_by: 0,\n          modified_by: 0\n        }\n      }).fetch();\n    }\n    if (psetsCustomer != null ? psetsCustomer._id : void 0) {\n      psetsCustomer_pos = Creator.getCollection(\"permission_objects\").find({\n        permission_set_id: psetsCustomer._id\n      }, {\n        fields: {\n          created: 0,\n          modified: 0,\n          created_by: 0,\n          modified_by: 0\n        }\n      }).fetch();\n    }\n    if (psetsCurrent.length > 0) {\n      set_ids = _.pluck(psetsCurrent, \"_id\");\n      psetsCurrent_pos = Creator.getCollection(\"permission_objects\").find({\n        permission_set_id: {\n          $in: set_ids\n        }\n      }).fetch();\n      psetsCurrentNames = _.pluck(psetsCurrent, \"name\");\n    }\n    psets = {\n      psetsAdmin: psetsAdmin,\n      psetsUser: psetsUser,\n      psetsCurrent: psetsCurrent,\n      psetsMember: psetsMember,\n      psetsGuest: psetsGuest,\n      psetsSupplier: psetsSupplier,\n      psetsCustomer: psetsCustomer,\n      isSpaceAdmin: isSpaceAdmin,\n      spaceUser: spaceUser,\n      psetsAdmin_pos: psetsAdmin_pos,\n      psetsUser_pos: psetsUser_pos,\n      psetsMember_pos: psetsMember_pos,\n      psetsGuest_pos: psetsGuest_pos,\n      psetsSupplier_pos: psetsSupplier_pos,\n      psetsCustomer_pos: psetsCustomer_pos,\n      psetsCurrent_pos: psetsCurrent_pos\n    };\n    permissions.assigned_apps = Creator.getAssignedApps.bind(psets)(spaceId, userId);\n    permissions.assigned_menus = Creator.getAssignedMenus.bind(psets)(spaceId, userId);\n    permissions.user_permission_sets = psetsCurrentNames;\n    _i = 0;\n    _.each(Creator.objectsByName, function(object, object_name) {\n      _i++;\n      if (!_.has(object, 'space') || !object.space || object.space === spaceId) {\n        if (!_.has(object, 'in_development') || object.in_development === '0' || (object.in_development !== '0' && isSpaceAdmin)) {\n          permissions.objects[object_name] = Creator.convertObject(clone(Creator.Objects[object_name]), spaceId);\n          return permissions.objects[object_name][\"permissions\"] = Creator.getObjectPermissions.bind(psets)(spaceId, userId, object_name);\n        }\n      }\n    });\n    return permissions;\n  };\n  unionPlus = function(array, other) {\n    if (!array && !other) {\n      return void 0;\n    }\n    if (!array) {\n      array = [];\n    }\n    if (!other) {\n      other = [];\n    }\n    return _.union(array, other);\n  };\n  intersectionPlus = function(array, other) {\n    if (!array && !other) {\n      return void 0;\n    }\n    if (!array) {\n      array = [];\n    }\n    if (!other) {\n      other = [];\n    }\n    return _.intersection(array, other);\n  };\n  extendPermissionProps = function(target, props) {\n    var filesProNames, propNames;\n    propNames = permissionPropNames;\n    return filesProNames = props ? _.each(propNames, function(propName) {\n      return target[propName] = props[propName];\n    }) : void 0;\n  };\n  overlayBaseBooleanPermissionProps = function(target, props) {\n    var propNames;\n    propNames = baseBooleanPermissionPropNames;\n    return _.each(propNames, function(propName) {\n      if (props[propName]) {\n        return target[propName] = true;\n      }\n    });\n  };\n  Creator.getAssignedApps = function(spaceId, userId) {\n    var apps, isSpaceAdmin, psetBase, psets, psetsAdmin, psetsCustomer, psetsSupplier, psetsUser, ref, ref1, spaceUser, userProfile;\n    psetsAdmin = this.psetsAdmin || Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'admin'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    });\n    psetsUser = this.psetsUser || Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'user'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    });\n    psetsSupplier = this.psetsMember || Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'supplier'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    });\n    psetsCustomer = this.psetsGuest || Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'customer'\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1\n      }\n    });\n    spaceUser = null;\n    if (userId) {\n      spaceUser = Creator.getCollection(\"space_users\").findOne({\n        space: spaceId,\n        user: userId\n      }, {\n        fields: {\n          profile: 1\n        }\n      });\n    }\n    if (spaceUser && spaceUser.profile) {\n      psets = Creator.getCollection(\"permission_set\").find({\n        space: spaceId,\n        $or: [\n          {\n            users: userId\n          }, {\n            name: spaceUser.profile\n          }\n        ]\n      }, {\n        fields: {\n          _id: 1,\n          assigned_apps: 1,\n          name: 1\n        }\n      }).fetch();\n    } else {\n      psets = Creator.getCollection(\"permission_set\").find({\n        users: userId,\n        space: spaceId\n      }, {\n        fields: {\n          _id: 1,\n          assigned_apps: 1,\n          name: 1\n        }\n      }).fetch();\n    }\n    isSpaceAdmin = _.isBoolean(this.isSpaceAdmin) ? this.isSpaceAdmin : Creator.isSpaceAdmin(spaceId, userId);\n    apps = [];\n    if (isSpaceAdmin) {\n      return [];\n    } else {\n      userProfile = (ref = Creator.getCollection(\"space_users\").findOne({\n        space: spaceId,\n        user: userId\n      }, {\n        fields: {\n          profile: 1\n        }\n      })) != null ? ref.profile : void 0;\n      psetBase = psetsUser;\n      if (userProfile) {\n        if (userProfile === 'supplier') {\n          psetBase = psetsSupplier;\n        } else if (userProfile === 'customer') {\n          psetBase = psetsCustomer;\n        }\n      }\n      if (psetBase != null ? (ref1 = psetBase.assigned_apps) != null ? ref1.length : void 0 : void 0) {\n        apps = _.union(apps, psetBase.assigned_apps);\n      } else {\n        return [];\n      }\n      _.each(psets, function(pset) {\n        if (!pset.assigned_apps) {\n          return;\n        }\n        if (pset.name === \"admin\" || pset.name === \"user\" || pset.name === 'supplier' || pset.name === 'customer') {\n          return;\n        }\n        return apps = _.union(apps, pset.assigned_apps);\n      });\n      return _.without(_.uniq(apps), void 0, null);\n    }\n  };\n  Creator.getAssignedMenus = function(spaceId, userId) {\n    var aboutMenu, adminMenus, allMenus, currentPsetNames, isSpaceAdmin, menus, otherMenuApps, otherMenus, psets, ref, ref1, result, userProfile;\n    psets = this.psetsCurrent || Creator.getCollection(\"permission_set\").find({\n      users: userId,\n      space: spaceId\n    }, {\n      fields: {\n        _id: 1,\n        assigned_apps: 1,\n        name: 1\n      }\n    }).fetch();\n    isSpaceAdmin = _.isBoolean(this.isSpaceAdmin) ? this.isSpaceAdmin : Creator.isSpaceAdmin(spaceId, userId);\n    adminMenus = (ref = Creator.Apps.admin) != null ? ref.admin_menus : void 0;\n    if (!adminMenus) {\n      return [];\n    }\n    aboutMenu = adminMenus.find(function(n) {\n      return n._id === 'about';\n    });\n    adminMenus = adminMenus.filter(function(n) {\n      return n._id !== 'about';\n    });\n    otherMenuApps = _.sortBy(_.filter(_.values(Creator.Apps), function(n) {\n      return n.admin_menus && n._id !== 'admin';\n    }), 'sort');\n    otherMenus = _.flatten(_.pluck(otherMenuApps, \"admin_menus\"));\n    allMenus = _.union(adminMenus, otherMenus, [aboutMenu]);\n    if (isSpaceAdmin) {\n      result = allMenus;\n    } else {\n      userProfile = ((ref1 = Creator.getCollection(\"space_users\").findOne({\n        space: spaceId,\n        user: userId\n      }, {\n        fields: {\n          profile: 1\n        }\n      })) != null ? ref1.profile : void 0) || 'user';\n      currentPsetNames = psets.map(function(n) {\n        return n.name;\n      });\n      menus = allMenus.filter(function(menu) {\n        var psetsMenu;\n        psetsMenu = menu.permission_sets;\n        if (psetsMenu && psetsMenu.indexOf(userProfile) > -1) {\n          return true;\n        }\n        return _.intersection(currentPsetNames, psetsMenu).length;\n      });\n      result = menus;\n    }\n    return _.sortBy(result, \"sort\");\n  };\n  findOne_permission_object = function(permission_objects, object_name, permission_set_id) {\n    if (_.isNull(permission_objects)) {\n      return null;\n    }\n    if (_.isArray(permission_objects)) {\n      return _.find(permission_objects, function(po) {\n        return po.object_name === object_name;\n      });\n    }\n    return Creator.getCollection(\"permission_objects\").findOne({\n      object_name: object_name,\n      permission_set_id: permission_set_id\n    });\n  };\n  find_permission_object = function(permission_objects, object_name, permission_set_ids) {\n    if (_.isNull(permission_objects)) {\n      return null;\n    }\n    if (_.isArray(permission_objects)) {\n      return _.filter(permission_objects, function(po) {\n        return po.object_name === object_name;\n      });\n    }\n    return Creator.getCollection(\"permission_objects\").find({\n      object_name: object_name,\n      permission_set_id: {\n        $in: permission_set_ids\n      }\n    }).fetch();\n  };\n  unionPermissionObjects = function(pos, object, psets) {\n    var result;\n    result = [];\n    _.each(object.permission_set, function(ops, ops_key) {\n      var currentPset, tempOps;\n      if ([\"admin\", \"user\", \"member\", \"guest\"].indexOf(ops_key) < 0) {\n        currentPset = psets.find(function(pset) {\n          return pset.name === ops_key;\n        });\n        if (currentPset) {\n          tempOps = _.clone(ops) || {};\n          tempOps.permission_set_id = currentPset._id;\n          tempOps.object_name = object.object_name;\n          return result.push(tempOps);\n        }\n      }\n    });\n    if (result.length) {\n      pos.forEach(function(po) {\n        var repeatIndex, repeatPo;\n        repeatIndex = 0;\n        repeatPo = result.find(function(item, index) {\n          repeatIndex = index;\n          return item.permission_set_id === po.permission_set_id;\n        });\n        if (repeatPo) {\n          return result[repeatIndex] = po;\n        } else {\n          return result.push(po);\n        }\n      });\n      return result;\n    } else {\n      return pos;\n    }\n  };\n  Creator.getObjectPermissions = function(spaceId, userId, object_name) {\n    var isSpaceAdmin, object, opsetAdmin, opsetCustomer, opsetGuest, opsetMember, opsetSupplier, opsetUser, permissions, pos, posAdmin, posCustomer, posGuest, posMember, posSupplier, posUser, prof, psets, psetsAdmin, psetsAdmin_pos, psetsCurrent_pos, psetsCustomer, psetsCustomer_pos, psetsGuest, psetsGuest_pos, psetsMember, psetsMember_pos, psetsSupplier, psetsSupplier_pos, psetsUser, psetsUser_pos, set_ids, spaceUser;\n    permissions = {};\n    object = Creator.getObject(object_name, spaceId);\n    if (spaceId === 'guest' || object_name === \"users\") {\n      permissions = _.clone(object.permission_set.guest) || {};\n      Creator.processPermissions(permissions);\n      return permissions;\n    }\n    psetsAdmin = _.isNull(this.psetsAdmin) || this.psetsAdmin ? this.psetsAdmin : Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'admin'\n    }, {\n      fields: {\n        _id: 1\n      }\n    });\n    psetsUser = _.isNull(this.psetsUser) || this.psetsUser ? this.psetsUser : Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'user'\n    }, {\n      fields: {\n        _id: 1\n      }\n    });\n    psetsMember = _.isNull(this.psetsMember) || this.psetsMember ? this.psetsMember : Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'member'\n    }, {\n      fields: {\n        _id: 1\n      }\n    });\n    psetsGuest = _.isNull(this.psetsGuest) || this.psetsGuest ? this.psetsGuest : Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'guest'\n    }, {\n      fields: {\n        _id: 1\n      }\n    });\n    psetsSupplier = _.isNull(this.psetsSupplier) || this.psetsSupplier ? this.psetsSupplier : Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'supplier'\n    }, {\n      fields: {\n        _id: 1\n      }\n    });\n    psetsCustomer = _.isNull(this.psetsCustomer) || this.psetsCustomer ? this.psetsCustomer : Creator.getCollection(\"permission_set\").findOne({\n      space: spaceId,\n      name: 'customer'\n    }, {\n      fields: {\n        _id: 1\n      }\n    });\n    psets = this.psetsCurrent;\n    if (!psets) {\n      spaceUser = null;\n      if (userId) {\n        spaceUser = Creator.getCollection(\"space_users\").findOne({\n          space: spaceId,\n          user: userId\n        }, {\n          fields: {\n            profile: 1\n          }\n        });\n      }\n      if (spaceUser && spaceUser.profile) {\n        psets = Creator.getCollection(\"permission_set\").find({\n          space: spaceId,\n          $or: [\n            {\n              users: userId\n            }, {\n              name: spaceUser.profile\n            }\n          ]\n        }, {\n          fields: {\n            _id: 1,\n            assigned_apps: 1,\n            name: 1\n          }\n        }).fetch();\n      } else {\n        psets = Creator.getCollection(\"permission_set\").find({\n          users: userId,\n          space: spaceId\n        }, {\n          fields: {\n            _id: 1,\n            assigned_apps: 1,\n            name: 1\n          }\n        }).fetch();\n      }\n    }\n    isSpaceAdmin = _.isBoolean(this.isSpaceAdmin) ? this.isSpaceAdmin : Creator.isSpaceAdmin(spaceId, userId);\n    psetsAdmin_pos = this.psetsAdmin_pos;\n    psetsUser_pos = this.psetsUser_pos;\n    psetsMember_pos = this.psetsMember_pos;\n    psetsGuest_pos = this.psetsGuest_pos;\n    psetsSupplier_pos = this.psetsSupplier_pos;\n    psetsCustomer_pos = this.psetsCustomer_pos;\n    psetsCurrent_pos = this.psetsCurrent_pos;\n    opsetAdmin = _.clone(object.permission_set.admin) || {};\n    opsetUser = _.clone(object.permission_set.user) || {};\n    opsetMember = _.clone(object.permission_set.member) || {};\n    opsetGuest = _.clone(object.permission_set.guest) || {};\n    opsetSupplier = _.clone(object.permission_set.supplier) || {};\n    opsetCustomer = _.clone(object.permission_set.customer) || {};\n    if (psetsAdmin) {\n      posAdmin = findOne_permission_object(psetsAdmin_pos, object_name, psetsAdmin._id);\n      extendPermissionProps(opsetAdmin, posAdmin);\n    }\n    if (psetsUser) {\n      posUser = findOne_permission_object(psetsUser_pos, object_name, psetsUser._id);\n      extendPermissionProps(opsetUser, posUser);\n    }\n    if (psetsMember) {\n      posMember = findOne_permission_object(psetsMember_pos, object_name, psetsMember._id);\n      extendPermissionProps(opsetMember, posMember);\n    }\n    if (psetsGuest) {\n      posGuest = findOne_permission_object(psetsGuest_pos, object_name, psetsGuest._id);\n      extendPermissionProps(opsetGuest, posGuest);\n    }\n    if (psetsSupplier) {\n      posSupplier = findOne_permission_object(psetsSupplier_pos, object_name, psetsSupplier._id);\n      extendPermissionProps(opsetSupplier, posSupplier);\n    }\n    if (psetsCustomer) {\n      posCustomer = findOne_permission_object(psetsCustomer_pos, object_name, psetsCustomer._id);\n      extendPermissionProps(opsetCustomer, posCustomer);\n    }\n    if (!userId) {\n      permissions = opsetAdmin;\n    } else {\n      if (isSpaceAdmin) {\n        permissions = opsetAdmin;\n      } else {\n        if (spaceId === 'common') {\n          permissions = opsetUser;\n        } else {\n          spaceUser = _.isNull(this.spaceUser) || this.spaceUser ? this.spaceUser : Creator.getCollection(\"space_users\").findOne({\n            space: spaceId,\n            user: userId\n          }, {\n            fields: {\n              profile: 1\n            }\n          });\n          if (spaceUser) {\n            prof = spaceUser.profile;\n            if (prof) {\n              if (prof === 'user') {\n                permissions = opsetUser;\n              } else if (prof === 'member') {\n                permissions = opsetMember;\n              } else if (prof === 'guest') {\n                permissions = opsetGuest;\n              } else if (prof === 'supplier') {\n                permissions = opsetSupplier;\n              } else if (prof === 'customer') {\n                permissions = opsetCustomer;\n              }\n            } else {\n              permissions = opsetUser;\n            }\n          } else {\n            permissions = opsetGuest;\n          }\n        }\n      }\n    }\n    if (psets.length > 0) {\n      set_ids = _.pluck(psets, \"_id\");\n      pos = find_permission_object(psetsCurrent_pos, object_name, set_ids);\n      pos = unionPermissionObjects(pos, object, psets);\n      _.each(pos, function(po) {\n        if (po.permission_set_id === (psetsAdmin != null ? psetsAdmin._id : void 0) || po.permission_set_id === (psetsUser != null ? psetsUser._id : void 0) || po.permission_set_id === (psetsMember != null ? psetsMember._id : void 0) || po.permission_set_id === (psetsGuest != null ? psetsGuest._id : void 0) || po.permission_set_id === (psetsSupplier != null ? psetsSupplier._id : void 0) || po.permission_set_id === (psetsCustomer != null ? psetsCustomer._id : void 0)) {\n          return;\n        }\n        if (_.isEmpty(permissions)) {\n          permissions = po;\n        }\n        overlayBaseBooleanPermissionProps(permissions, po);\n        permissions.disabled_list_views = intersectionPlus(permissions.disabled_list_views, po.disabled_list_views);\n        permissions.disabled_actions = intersectionPlus(permissions.disabled_actions, po.disabled_actions);\n        permissions.unreadable_fields = intersectionPlus(permissions.unreadable_fields, po.unreadable_fields);\n        permissions.uneditable_fields = intersectionPlus(permissions.uneditable_fields, po.uneditable_fields);\n        permissions.unrelated_objects = intersectionPlus(permissions.unrelated_objects, po.unrelated_objects);\n        return permissions.uneditable_related_list = intersectionPlus(permissions.uneditable_related_list, po.uneditable_related_list);\n      });\n    }\n    if (object.is_view) {\n      permissions.allowCreate = false;\n      permissions.allowEdit = false;\n      permissions.allowDelete = false;\n      permissions.modifyAllRecords = false;\n      permissions.modifyCompanyRecords = false;\n      permissions.disabled_actions = [];\n    }\n    Creator.processPermissions(permissions);\n    if (object.permission_set.owner) {\n      permissions.owner = object.permission_set.owner;\n    }\n    return permissions;\n  };\n  Meteor.methods({\n    \"creator.object_permissions\": function(spaceId) {\n      return Creator.getAllPermissions(spaceId, this.userId);\n    }\n  });\n}\n","\nsteedosCore = require('@steedos/core')\n\nMeteor.startup ()->\n\tcreator_db_url = process.env.MONGO_URL_CREATOR\n\toplog_url = process.env.MONGO_OPLOG_URL_CREATOR\n\tif creator_db_url\n\t\tif !oplog_url\n\t\t\tthrow new Meteor.Error(500, \"Please configure environment variables: MONGO_OPLOG_URL_CREATOR\")\n\t\tCreator._CREATOR_DATASOURCE = {_driver: new MongoInternals.RemoteCollectionDriver(creator_db_url, {oplogUrl: oplog_url})}\n\nCreator.getCollectionName = (object)->\n#\tif object.table_name && object.table_name.endsWith(\"__c\")\n#\t\treturn object.table_name\n#\telse\n#\t\treturn object.name\n\treturn object.name\nCreator.createCollection = (object)->\n\tcollection_key = Creator.getCollectionName(object)\n\tif db[collection_key]\n\t\treturn db[collection_key]\n\telse if object.db\n\t\treturn object.db\n\n\tif Creator.Collections[collection_key]\n\t\treturn Creator.Collections[collection_key]\n\telse\n\t\tif object.custom\n\t\t\treturn steedosCore.newCollection(collection_key, Creator._CREATOR_DATASOURCE)\n\t\telse\n\t\t\tif collection_key == '_sms_queue' && SMSQueue?.collection\n\t\t\t\treturn SMSQueue.collection\n\t\t\treturn steedosCore.newCollection(collection_key)\n\n\n","var steedosCore;\n\nsteedosCore = require('@steedos/core');\n\nMeteor.startup(function() {\n  var creator_db_url, oplog_url;\n  creator_db_url = process.env.MONGO_URL_CREATOR;\n  oplog_url = process.env.MONGO_OPLOG_URL_CREATOR;\n  if (creator_db_url) {\n    if (!oplog_url) {\n      throw new Meteor.Error(500, \"Please configure environment variables: MONGO_OPLOG_URL_CREATOR\");\n    }\n    return Creator._CREATOR_DATASOURCE = {\n      _driver: new MongoInternals.RemoteCollectionDriver(creator_db_url, {\n        oplogUrl: oplog_url\n      })\n    };\n  }\n});\n\nCreator.getCollectionName = function(object) {\n  return object.name;\n};\n\nCreator.createCollection = function(object) {\n  var collection_key;\n  collection_key = Creator.getCollectionName(object);\n  if (db[collection_key]) {\n    return db[collection_key];\n  } else if (object.db) {\n    return object.db;\n  }\n  if (Creator.Collections[collection_key]) {\n    return Creator.Collections[collection_key];\n  } else {\n    if (object.custom) {\n      return steedosCore.newCollection(collection_key, Creator._CREATOR_DATASOURCE);\n    } else {\n      if (collection_key === '_sms_queue' && (typeof SMSQueue !== \"undefined\" && SMSQueue !== null ? SMSQueue.collection : void 0)) {\n        return SMSQueue.collection;\n      }\n      return steedosCore.newCollection(collection_key);\n    }\n  }\n};\n","Creator.actionsByName = {}\n\nif Meteor.isClient\n\t# 定义全局 actions 函数\t\n\tCreator.actions = (actions)->\n\t\t_.each actions, (todo, action_name)->\n\t\t\tCreator.actionsByName[action_name] = todo \n\n\tCreator.executeAction = (object_name, action, record_id, item_element, list_view_id, record, callback)->\n\t\tif action && action.type == 'word-print'\n\t\t\tif record_id\n\t\t\t\tfilters = ['_id', '=', record_id]\n\t\t\telse\n\t\t\t\tfilters = ObjectGrid.getFilters(object_name, list_view_id, false, null, null)\n\t\t\turl = \"/api/v4/word_templates/\" + action.word_template + \"/print\" + \"?filters=\" + SteedosFilters.formatFiltersToODataQuery(filters);\n\t\t\turl = Steedos.absoluteUrl(url);\n\t\t\treturn window.open(url);\n\n\t\tobj = Creator.getObject(object_name)\n\t\tif action?.todo\n\t\t\tif typeof action.todo == \"string\"\n\t\t\t\ttodo = Creator.actionsByName[action.todo]\n\t\t\telse if typeof action.todo == \"function\"\n\t\t\t\ttodo = action.todo\t\n\t\t\tif !record && object_name && record_id\n\t\t\t\trecord = Creator.odata.get(object_name, record_id)\n\t\t\tif todo\n\t\t\t\t# item_element为空时应该设置默认值（对象的name字段），否则moreArgs拿到的后续参数位置就不对\n\t\t\t\titem_element = if item_element then item_element else \"\"\n\t\t\t\tmoreArgs = Array.prototype.slice.call(arguments, 3)\n\t\t\t\ttodoArgs = [object_name, record_id].concat(moreArgs)\n\t\t\t\ttodo.apply {\n\t\t\t\t\tobject_name: object_name\n\t\t\t\t\trecord_id: record_id\n\t\t\t\t\tobject: obj\n\t\t\t\t\taction: action\n\t\t\t\t\titem_element: item_element\n\t\t\t\t\trecord: record\n\t\t\t\t}, todoArgs\n\t\t\telse\n\t\t\t\ttoastr.warning(t(\"_object_actions_none_todo\"))\n\t\telse\n\t\t\ttoastr.warning(t(\"_object_actions_none_todo\"))\n\n\n\t_deleteRecord = (object_name, record_id, record_title, list_view_id, record, call_back, call_back_error)->\n\t\t# console.log(\"===_deleteRecord===\", object_name, record_id, record_title, list_view_id, record, call_back, call_back_error);\n\t\tobject = Creator.getObject(object_name)\n\t\tpreviousDoc = FormManager.getPreviousDoc(object_name, record_id, 'delete')\n\t\tCreator.odata.delete object_name, record_id, ()->\n\t\t\tif record_title\n\t\t\t\t# info = object.label + \"\\\"#{record_title}\\\"\" + \"已删除\"\n\t\t\t\tinfo =t \"creator_record_remove_swal_title_suc\", object.label + \"\\\"#{record_title}\\\"\"\n\t\t\telse\n\t\t\t\tinfo = t('creator_record_remove_swal_suc')\n\t\t\ttoastr.success info\n\t\t\tif call_back and typeof call_back == \"function\"\n\t\t\t\tcall_back()\n\n\t\t\tFormManager.runHook(object_name, 'delete', 'after', {_id: record_id, previousDoc: previousDoc})\n\t\t, (error)->\n\t\t\tif call_back_error and typeof call_back_error == \"function\"\n\t\t\t\tcall_back_error()\n\t\t\tFormManager.runHook(object_name, 'delete', 'error', {_id: record_id, error: error})\n\n\tCreator.relatedObjectStandardNew = (related_object_name)->\n\t\trelateObject = Creator.getObject(related_object_name)\n\t\tcollection_name = relateObject.label\n\t\tcollection = \"Creator.Collections.#{Creator.getObject(related_object_name)._collection_name}\"\n\t\tcurrent_object_name = Session.get(\"object_name\")\n\t\tcurrent_record_id = Session.get(\"record_id\")\n\t\tids = Creator.TabularSelectedIds[related_object_name]\n\t\tinitialValues = {};\n\t\tif ids?.length\n\t\t\t# 列表有选中项时，取第一个选中项，复制其内容到新建窗口中\n\t\t\t# 这的第一个指的是第一次勾选的选中项，而不是列表中已勾选的第一项\n\t\t\trecord_id = ids[0]\n\t\t\tdoc = Creator.odata.get(related_object_name, record_id)\n\t\t\tinitialValues = doc\n\t\t\t# “保存并新建”操作中自动打开的新窗口中需要再次复制最新的doc内容到新窗口中\n\t\t\tSession.set 'cmShowAgainDuplicated', true\n\t\telse\n\t\t\tdefaultDoc = FormManager.getRelatedInitialValues(current_object_name, current_record_id, related_object_name);\n\t\t\tif !_.isEmpty(defaultDoc)\n\t\t\t\tinitialValues = defaultDoc\n\t\tif relateObject?.version >= 2\n\t\t\treturn SteedosUI.showModal(stores.ComponentRegistry.components.ObjectForm, {\n\t\t\t\tname: \"#{related_object_name}_standard_new_form\",\n\t\t\t\tobjectApiName: related_object_name,\n\t\t\t\ttitle: '新建 ' + relateObject.label,\n\t\t\t\tinitialValues: initialValues,\n\t\t\t\tafterInsert: (result)->\n\t\t\t\t\tsetTimeout(()->\n\t\t\t\t\t\t# ObjectForm有缓存，新建子表记录可能会有汇总字段，需要刷新表单数据\n\t\t\t\t\t\tif Creator.getObject(current_object_name).version > 1\n\t\t\t\t\t\t\tSteedosUI.reloadRecord(current_object_name, current_record_id)\n\t\t\t\t\t\tFlowRouter.reload();\n\t\t\t\t\t, 1);\n\t\t\t\t\treturn true;\n\t\t\t}, null, {iconPath: '/assets/icons'})\n\n\n\t\tif ids?.length\n\t\t\t# 列表有选中项时，取第一个选中项，复制其内容到新建窗口中\n\t\t\t# 这的第一个指的是第一次勾选的选中项，而不是列表中已勾选的第一项\n\t\t\tSession.set 'cmDoc', initialValues\n\t\t\t# “保存并新建”操作中自动打开的新窗口中需要再次复制最新的doc内容到新窗口中\n\t\t\tSession.set 'cmShowAgainDuplicated', true\n\t\telse\n\t\t\tif !_.isEmpty(initialValues)\n\t\t\t\tSession.set 'cmDoc', initialValues\n\n\t\tSession.set(\"action_fields\", undefined)\n\t\tSession.set(\"action_collection\", collection)\n\t\tSession.set(\"action_collection_name\", collection_name)\n\t\tSession.set(\"action_save_and_insert\", false)\n\t\tMeteor.defer ()->\n\t\t\t$(\".creator-add-related\").click()\n\t\treturn\n\n\tCreator.actions \n\t\t# 在此定义全局 actions\n\t\t\"standard_query\": ()->\n\t\t\tModal.show(\"standard_query_modal\")\n\n\t\t\"standard_new\": (object_name, record_id, fields)->\n\t\t\t# current_record_id = Session.get(\"record_id\")\n\t\t\t# if current_record_id\n\t\t\t# \t# amis 相关子表右上角新建\n\t\t\t# \tCreator.relatedObjectStandardNew(object_name)\n\t\t\t# \treturn \n\t\t\tobject = Creator.getObject(object_name);\n\t\t\tgridName = this.action.gridName;\n\t\t\tisRelated = this.action.isRelated;\n\t\t\tif isRelated\n\t\t\t\trelatedFieldName = this.action.relatedFieldName;\n\t\t\t\tmasterRecordId = this.action.masterRecordId;\n\t\t\t\tinitialValues = this.action.initialValues\n\t\t\t\tif !initialValues\n\t\t\t\t\tinitialValues = {};\n\t\t\t\t\tinitialValues[relatedFieldName] = masterRecordId\n\t\t\telse\n\t\t\t\tinitialValues={}\n\t\t\t\tif(gridName)\n\t\t\t\t\tselectedRows = window.gridRefs?[gridName].current?.api?.getSelectedRows()\n\t\t\t\telse\n\t\t\t\t\tselectedRows = window.gridRef?.current?.api?.getSelectedRows()\t\n\t\t\t\t\n\t\t\t\tif selectedRows?.length\n\t\t\t\t\trecord_id = selectedRows[0]._id;\n\t\t\t\t\tif record_id\n\t\t\t\t\t\tinitialValues = Creator.odata.get(object_name, record_id)\n\n\t\t\t\telse\n\t\t\t\t\tinitialValues = FormManager.getInitialValues(object_name)\n\n\t\t\tif object?.version >= 2\n\t\t\t\treturn Steedos.Page.Form.StandardNew.render(Session.get(\"app_id\"), object_name, t('New') + ' ' + object.label, initialValues , {gridName: gridName});\n\t\t\tSession.set 'action_object_name', object_name\n\t\t\tif selectedRows?.length\n\t\t\t\t# 列表有选中项时，取第一个选中项，复制其内容到新建窗口中\n\t\t\t\t# 这的第一个指的是第一次勾选的选中项，而不是列表中已勾选的第一项\n\t\t\t\tSession.set 'cmDoc', initialValues\n\t\t\t\t# “保存并新建”操作中自动打开的新窗口中需要再次复制最新的doc内容到新窗口中\n\t\t\t\tSession.set 'cmShowAgainDuplicated', true\n\t\t\telse\n\t\t\t\tSession.set 'cmDoc', initialValues\n\t\t\tMeteor.defer ()->\n\t\t\t\t$(\".creator-add\").click()\n\t\t\treturn \n\n\t\t\"standard_open_view\": (object_name, record_id, fields)->\n\t\t\thref = Creator.getObjectUrl(object_name, record_id)\n\t\t\tFlowRouter.redirect(href)\n\t\t\treturn false\n\n\t\t\"standard_edit\": (object_name, record_id, fields)->\n\t\t\tif record_id\n\t\t\t\tobject = Creator.getObject(object_name);\n\t\t\t\tif object?.version >= 2\n\t\t\t\t\treturn Steedos.Page.Form.StandardEdit.render(Session.get(\"app_id\"), object_name, t('Edit') + ' ' + object.label, record_id, {\n\t\t\t\t\t\tgridName: this.action.gridName\n\t\t\t\t\t})\n\t\t\t\tif Steedos.isMobile() && false\n#\t\t\t\t\trecord = Creator.getObjectRecord(object_name, record_id)\n#\t\t\t\t\tSession.set 'cmDoc', record\n#\t\t\t\t\tSession.set 'reload_dxlist', false\n\t\t\t\t\tSession.set 'action_object_name', object_name\n\t\t\t\t\tSession.set 'action_record_id', record_id\n\t\t\t\t\tif this.record\n\t\t\t\t\t\tSession.set 'cmDoc', this.record\n\t\t\t\t\tMeteor.defer ()->\n\t\t\t\t\t\t$(\".btn-edit-record\").click()\n\t\t\t\telse\n\t\t\t\t\tSession.set 'action_object_name', object_name\n\t\t\t\t\tSession.set 'action_record_id', record_id\n\t\t\t\t\tif this.record\n\t\t\t\t\t\tSession.set 'cmDoc', this.record\n\t\t\t\t\t\tMeteor.defer ()->\n\t\t\t\t\t\t\t$(\".btn.creator-edit\").click()\n\n\t\t\"standard_delete\": (object_name, record_id, record_title, list_view_id, record, call_back)->\n\t\t\tgridName = this.action.gridName;\n\t\t\t# console.log(\"===standard_delete===\", object_name, record_id, record_title, list_view_id, record, call_back);\n\t\t\tif record_id\n\t\t\t\tbeforeHook = FormManager.runHook(object_name, 'delete', 'before', {_id: record_id})\n\t\t\t\tif !beforeHook\n\t\t\t\t\treturn false;\n\t\t\tobject = Creator.getObject(object_name)\n\t\t\tnameField = object.NAME_FIELD_KEY || \"name\"\n\n\t\t\tunless list_view_id\n\t\t\t\tlist_view_id = Session.get(\"list_view_id\")\n\t\t\tunless list_view_id\n\t\t\t\tlist_view_id = \"all\"\n\n\t\t\tif(!_.isString(record_title) && record_title)\n\t\t\t\trecord_title = record_title[nameField]\n\t\t\t\n\t\t\tif record && !record_title\n\t\t\t\trecord_title = record[nameField]\n\t\t\t\n\t\t\ti18nTitleKey = \"creator_record_remove_swal_title\"\n\t\t\ti18nTextKey = \"creator_record_remove_swal_text\"\n\n\t\t\tunless record_id\n\t\t\t\ti18nTitleKey = \"creator_record_remove_many_swal_title\"\n\t\t\t\ti18nTextKey = \"creator_record_remove_many_swal_text\"\n\n\t\t\t\t# 如果是批量删除，则传入的list_view_id为列表视图的name，用于获取列表选中项\n\t\t\t\t# 主列表规则是\"listview_#{object_name}_#{list_view_id}\"，相关表规则是\"related_listview_#{object_name}_#{related_object_name}_#{related_field_name}\"\n\t\t\t\tselectedRecords = SteedosUI.getTableSelectedRows(gridName || list_view_id)\n\t\t\t\tif !selectedRecords || !selectedRecords.length\n\t\t\t\t\ttoastr.warning(t(\"creator_record_remove_many_no_selection\"))\n\t\t\t\t\treturn\n\n\t\t\tif record_title\n\t\t\t\ttext = t i18nTextKey, \"#{object.label} \\\"#{record_title}\\\"\"\n\t\t\telse\n\t\t\t\ttext = t i18nTextKey, \"#{object.label}\"\n\t\t\tswal\n\t\t\t\ttitle: t i18nTitleKey, \"#{object.label}\"\n\t\t\t\ttext: \"<div class='delete-creator-warning'>#{text}</div>\"\n\t\t\t\thtml: true\n\t\t\t\tshowCancelButton:true\n\t\t\t\tconfirmButtonText: t('Delete')\n\t\t\t\tcancelButtonText: t('Cancel')\n\t\t\t\t(option) ->\n\t\t\t\t\tif option\n\t\t\t\t\t\tif record_id\n\t\t\t\t\t\t\t# 单条记录删除\n\t\t\t\t\t\t\t_deleteRecord object_name, record_id, record_title, list_view_id, record, ()->\n\t\t\t\t\t\t\t\t# 文件版本为\"cfs.files.filerecord\"，需要替换为\"cfs-files-filerecord\"\n\t\t\t\t\t\t\t\tgridObjectNameClass = object_name.replace(/\\./g,\"-\")\n\t\t\t\t\t\t\t\tgridContainer = $(\".gridContainer.#{gridObjectNameClass}\")\n\t\t\t\t\t\t\t\tunless gridContainer?.length\n\t\t\t\t\t\t\t\t\tif window.opener\n\t\t\t\t\t\t\t\t\t\tisOpenerRemove = false\n\t\t\t\t\t\t\t\t\t\tgridContainer = window.opener.$(\".gridContainer.#{gridObjectNameClass}\")\n\t\t\t\t\t\t\t\ttry\n\t\t\t\t\t\t\t\t\t# ObjectForm有缓存，删除子表记录可能会有汇总字段，需要刷新表单数据\n\t\t\t\t\t\t\t\t\tcurrent_object_name = Session.get(\"object_name\")\n\t\t\t\t\t\t\t\t\tcurrent_record_id = Session.get(\"record_id\")\n\t\t\t\t\t\t\t\t\tif current_object_name && Creator.getObject(current_object_name)?.version > 1\n\t\t\t\t\t\t\t\t\t\tSteedosUI.reloadRecord(current_object_name, current_record_id)\n\t\t\t\t\t\t\t\t\tif FlowRouter.current().route.path.endsWith(\"/:record_id\")\n\t\t\t\t\t\t\t\t\t\tif object_name != Session.get(\"object_name\")\n\t\t\t\t\t\t\t\t\t\t\tFlowRouter.reload();\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\twindow.refreshGrid(gridName);\n\t\t\t\t\t\t\t\tcatch _e\n\t\t\t\t\t\t\t\t\tconsole.error(_e);\n\t\t\t\t\t\t\t\tif gridContainer?.length\n\t\t\t\t\t\t\t\t\tif object.enable_tree\n\t\t\t\t\t\t\t\t\t\tdxDataGridInstance = gridContainer.dxTreeList().dxTreeList('instance')\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tdxDataGridInstance = gridContainer.dxDataGrid().dxDataGrid('instance')\n\t\t\t\t\t\t\t\tif dxDataGridInstance\n\t\t\t\t\t\t\t\t\tif object.enable_tree\n\t\t\t\t\t\t\t\t\t\tdxDataGridInstance.refresh()\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tif object_name != Session.get(\"object_name\")\n\t\t\t\t\t\t\t\t\t\t\tFlowRouter.reload();\n\t\t\t\t\t\t\t\t\t\t# else\n\t\t\t\t\t\t\t\t\t\t# \tTemplate.creator_grid.refresh(dxDataGridInstance)\n\t\t\t\t\t\t\t\trecordUrl = Creator.getObjectUrl(object_name, record_id)\n\t\t\t\t\t\t\t\ttempNavRemoved = Creator.removeTempNavItem(object_name, recordUrl) #无论是在记录详细界面还是列表界面执行删除操作，都会把临时导航删除掉\n\t\t\t\t\t\t\t\tif isOpenerRemove or !dxDataGridInstance\n\t\t\t\t\t\t\t\t\tif isOpenerRemove\n\t\t\t\t\t\t\t\t\t\twindow.close()\n\t\t\t\t\t\t\t\t\telse if record_id == Session.get(\"record_id\") and list_view_id != 'calendar'\n\t\t\t\t\t\t\t\t\t\tappid = Session.get(\"app_id\")\n\t\t\t\t\t\t\t\t\t\tunless tempNavRemoved\n\t\t\t\t\t\t\t\t\t\t\t# 如果确实删除了临时导航，就可能已经重定向到上一个页面了，没必要再重定向一次\n\t\t\t\t\t\t\t\t\t\t\tFlowRouter.go \"/app/#{appid}/#{object_name}/grid/#{list_view_id}\"\n\t\t\t\t\t\t\t\tif call_back and typeof call_back == \"function\"\n\t\t\t\t\t\t\t\t\tcall_back()\t\t\t\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t# 批量删除\n\t\t\t\t\t\t\tif selectedRecords && selectedRecords.length\n\t\t\t\t\t\t\t\t$(\"body\").addClass(\"loading\")\n\t\t\t\t\t\t\t\tdeleteCounter = 0;\n\t\t\t\t\t\t\t\tafterBatchesDelete = ()->\n\t\t\t\t\t\t\t\t\tdeleteCounter++\n\t\t\t\t\t\t\t\t\tif deleteCounter >= selectedRecords.length\n\t\t\t\t\t\t\t\t\t\t# console.log(\"deleteCounter, selectedRecords.length===\", deleteCounter, selectedRecords.length);\n\t\t\t\t\t\t\t\t\t\t$(\"body\").removeClass(\"loading\")\n\t\t\t\t\t\t\t\t\t\twindow.refreshGrid(gridName);\n\t\t\t\t\t\t\t\tselectedRecords.forEach (record)->\n\t\t\t\t\t\t\t\t\trecord_id = record._id\n\t\t\t\t\t\t\t\t\tbeforeHook = FormManager.runHook(object_name, 'delete', 'before', {_id: record_id})\n\t\t\t\t\t\t\t\t\tif !beforeHook\n\t\t\t\t\t\t\t\t\t\tafterBatchesDelete()\n\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\trecordTitle = record[nameField] || record_id\n\t\t\t\t\t\t\t\t\t_deleteRecord object_name, record._id, recordTitle, list_view_id, record, (()->\n\t\t\t\t\t\t\t\t\t\trecordUrl = Creator.getObjectUrl(object_name, record_id)\n\t\t\t\t\t\t\t\t\t\tCreator.removeTempNavItem(object_name, recordUrl) #无论是在记录详细界面还是列表界面执行删除操作，都会把临时导航删除掉\n\t\t\t\t\t\t\t\t\t\tafterBatchesDelete()\n\t\t\t\t\t\t\t\t\t), ()->\n\t\t\t\t\t\t\t\t\t\tafterBatchesDelete()","var _deleteRecord;\n\nCreator.actionsByName = {};\n\nif (Meteor.isClient) {\n  Creator.actions = function(actions) {\n    return _.each(actions, function(todo, action_name) {\n      return Creator.actionsByName[action_name] = todo;\n    });\n  };\n  Creator.executeAction = function(object_name, action, record_id, item_element, list_view_id, record, callback) {\n    var filters, moreArgs, obj, todo, todoArgs, url;\n    if (action && action.type === 'word-print') {\n      if (record_id) {\n        filters = ['_id', '=', record_id];\n      } else {\n        filters = ObjectGrid.getFilters(object_name, list_view_id, false, null, null);\n      }\n      url = \"/api/v4/word_templates/\" + action.word_template + \"/print\" + \"?filters=\" + SteedosFilters.formatFiltersToODataQuery(filters);\n      url = Steedos.absoluteUrl(url);\n      return window.open(url);\n    }\n    obj = Creator.getObject(object_name);\n    if (action != null ? action.todo : void 0) {\n      if (typeof action.todo === \"string\") {\n        todo = Creator.actionsByName[action.todo];\n      } else if (typeof action.todo === \"function\") {\n        todo = action.todo;\n      }\n      if (!record && object_name && record_id) {\n        record = Creator.odata.get(object_name, record_id);\n      }\n      if (todo) {\n        item_element = item_element ? item_element : \"\";\n        moreArgs = Array.prototype.slice.call(arguments, 3);\n        todoArgs = [object_name, record_id].concat(moreArgs);\n        return todo.apply({\n          object_name: object_name,\n          record_id: record_id,\n          object: obj,\n          action: action,\n          item_element: item_element,\n          record: record\n        }, todoArgs);\n      } else {\n        return toastr.warning(t(\"_object_actions_none_todo\"));\n      }\n    } else {\n      return toastr.warning(t(\"_object_actions_none_todo\"));\n    }\n  };\n  _deleteRecord = function(object_name, record_id, record_title, list_view_id, record, call_back, call_back_error) {\n    var object, previousDoc;\n    object = Creator.getObject(object_name);\n    previousDoc = FormManager.getPreviousDoc(object_name, record_id, 'delete');\n    return Creator.odata[\"delete\"](object_name, record_id, function() {\n      var info;\n      if (record_title) {\n        info = t(\"creator_record_remove_swal_title_suc\", object.label + (\"\\\"\" + record_title + \"\\\"\"));\n      } else {\n        info = t('creator_record_remove_swal_suc');\n      }\n      toastr.success(info);\n      if (call_back && typeof call_back === \"function\") {\n        call_back();\n      }\n      return FormManager.runHook(object_name, 'delete', 'after', {\n        _id: record_id,\n        previousDoc: previousDoc\n      });\n    }, function(error) {\n      if (call_back_error && typeof call_back_error === \"function\") {\n        call_back_error();\n      }\n      return FormManager.runHook(object_name, 'delete', 'error', {\n        _id: record_id,\n        error: error\n      });\n    });\n  };\n  Creator.relatedObjectStandardNew = function(related_object_name) {\n    var collection, collection_name, current_object_name, current_record_id, defaultDoc, doc, ids, initialValues, record_id, relateObject;\n    relateObject = Creator.getObject(related_object_name);\n    collection_name = relateObject.label;\n    collection = \"Creator.Collections.\" + (Creator.getObject(related_object_name)._collection_name);\n    current_object_name = Session.get(\"object_name\");\n    current_record_id = Session.get(\"record_id\");\n    ids = Creator.TabularSelectedIds[related_object_name];\n    initialValues = {};\n    if (ids != null ? ids.length : void 0) {\n      record_id = ids[0];\n      doc = Creator.odata.get(related_object_name, record_id);\n      initialValues = doc;\n      Session.set('cmShowAgainDuplicated', true);\n    } else {\n      defaultDoc = FormManager.getRelatedInitialValues(current_object_name, current_record_id, related_object_name);\n      if (!_.isEmpty(defaultDoc)) {\n        initialValues = defaultDoc;\n      }\n    }\n    if ((relateObject != null ? relateObject.version : void 0) >= 2) {\n      return SteedosUI.showModal(stores.ComponentRegistry.components.ObjectForm, {\n        name: related_object_name + \"_standard_new_form\",\n        objectApiName: related_object_name,\n        title: '新建 ' + relateObject.label,\n        initialValues: initialValues,\n        afterInsert: function(result) {\n          setTimeout(function() {\n            if (Creator.getObject(current_object_name).version > 1) {\n              SteedosUI.reloadRecord(current_object_name, current_record_id);\n            }\n            return FlowRouter.reload();\n          }, 1);\n          return true;\n        }\n      }, null, {\n        iconPath: '/assets/icons'\n      });\n    }\n    if (ids != null ? ids.length : void 0) {\n      Session.set('cmDoc', initialValues);\n      Session.set('cmShowAgainDuplicated', true);\n    } else {\n      if (!_.isEmpty(initialValues)) {\n        Session.set('cmDoc', initialValues);\n      }\n    }\n    Session.set(\"action_fields\", void 0);\n    Session.set(\"action_collection\", collection);\n    Session.set(\"action_collection_name\", collection_name);\n    Session.set(\"action_save_and_insert\", false);\n    Meteor.defer(function() {\n      return $(\".creator-add-related\").click();\n    });\n  };\n  Creator.actions({\n    \"standard_query\": function() {\n      return Modal.show(\"standard_query_modal\");\n    },\n    \"standard_new\": function(object_name, record_id, fields) {\n      var gridName, initialValues, isRelated, masterRecordId, object, ref, ref1, ref2, ref3, ref4, ref5, relatedFieldName, selectedRows;\n      object = Creator.getObject(object_name);\n      gridName = this.action.gridName;\n      isRelated = this.action.isRelated;\n      if (isRelated) {\n        relatedFieldName = this.action.relatedFieldName;\n        masterRecordId = this.action.masterRecordId;\n        initialValues = this.action.initialValues;\n        if (!initialValues) {\n          initialValues = {};\n          initialValues[relatedFieldName] = masterRecordId;\n        }\n      } else {\n        initialValues = {};\n        if (gridName) {\n          selectedRows = (ref = window.gridRefs) != null ? (ref1 = ref[gridName].current) != null ? (ref2 = ref1.api) != null ? ref2.getSelectedRows() : void 0 : void 0 : void 0;\n        } else {\n          selectedRows = (ref3 = window.gridRef) != null ? (ref4 = ref3.current) != null ? (ref5 = ref4.api) != null ? ref5.getSelectedRows() : void 0 : void 0 : void 0;\n        }\n        if (selectedRows != null ? selectedRows.length : void 0) {\n          record_id = selectedRows[0]._id;\n          if (record_id) {\n            initialValues = Creator.odata.get(object_name, record_id);\n          }\n        } else {\n          initialValues = FormManager.getInitialValues(object_name);\n        }\n      }\n      if ((object != null ? object.version : void 0) >= 2) {\n        return Steedos.Page.Form.StandardNew.render(Session.get(\"app_id\"), object_name, t('New') + ' ' + object.label, initialValues, {\n          gridName: gridName\n        });\n      }\n      Session.set('action_object_name', object_name);\n      if (selectedRows != null ? selectedRows.length : void 0) {\n        Session.set('cmDoc', initialValues);\n        Session.set('cmShowAgainDuplicated', true);\n      } else {\n        Session.set('cmDoc', initialValues);\n      }\n      Meteor.defer(function() {\n        return $(\".creator-add\").click();\n      });\n    },\n    \"standard_open_view\": function(object_name, record_id, fields) {\n      var href;\n      href = Creator.getObjectUrl(object_name, record_id);\n      FlowRouter.redirect(href);\n      return false;\n    },\n    \"standard_edit\": function(object_name, record_id, fields) {\n      var object;\n      if (record_id) {\n        object = Creator.getObject(object_name);\n        if ((object != null ? object.version : void 0) >= 2) {\n          return Steedos.Page.Form.StandardEdit.render(Session.get(\"app_id\"), object_name, t('Edit') + ' ' + object.label, record_id, {\n            gridName: this.action.gridName\n          });\n        }\n        if (Steedos.isMobile() && false) {\n          Session.set('action_object_name', object_name);\n          Session.set('action_record_id', record_id);\n          if (this.record) {\n            Session.set('cmDoc', this.record);\n          }\n          return Meteor.defer(function() {\n            return $(\".btn-edit-record\").click();\n          });\n        } else {\n          Session.set('action_object_name', object_name);\n          Session.set('action_record_id', record_id);\n          if (this.record) {\n            Session.set('cmDoc', this.record);\n            return Meteor.defer(function() {\n              return $(\".btn.creator-edit\").click();\n            });\n          }\n        }\n      }\n    },\n    \"standard_delete\": function(object_name, record_id, record_title, list_view_id, record, call_back) {\n      var beforeHook, gridName, i18nTextKey, i18nTitleKey, nameField, object, selectedRecords, text;\n      gridName = this.action.gridName;\n      if (record_id) {\n        beforeHook = FormManager.runHook(object_name, 'delete', 'before', {\n          _id: record_id\n        });\n        if (!beforeHook) {\n          return false;\n        }\n      }\n      object = Creator.getObject(object_name);\n      nameField = object.NAME_FIELD_KEY || \"name\";\n      if (!list_view_id) {\n        list_view_id = Session.get(\"list_view_id\");\n      }\n      if (!list_view_id) {\n        list_view_id = \"all\";\n      }\n      if (!_.isString(record_title) && record_title) {\n        record_title = record_title[nameField];\n      }\n      if (record && !record_title) {\n        record_title = record[nameField];\n      }\n      i18nTitleKey = \"creator_record_remove_swal_title\";\n      i18nTextKey = \"creator_record_remove_swal_text\";\n      if (!record_id) {\n        i18nTitleKey = \"creator_record_remove_many_swal_title\";\n        i18nTextKey = \"creator_record_remove_many_swal_text\";\n        selectedRecords = SteedosUI.getTableSelectedRows(gridName || list_view_id);\n        if (!selectedRecords || !selectedRecords.length) {\n          toastr.warning(t(\"creator_record_remove_many_no_selection\"));\n          return;\n        }\n      }\n      if (record_title) {\n        text = t(i18nTextKey, object.label + \" \\\"\" + record_title + \"\\\"\");\n      } else {\n        text = t(i18nTextKey, \"\" + object.label);\n      }\n      return swal({\n        title: t(i18nTitleKey, \"\" + object.label),\n        text: \"<div class='delete-creator-warning'>\" + text + \"</div>\",\n        html: true,\n        showCancelButton: true,\n        confirmButtonText: t('Delete'),\n        cancelButtonText: t('Cancel')\n      }, function(option) {\n        var afterBatchesDelete, deleteCounter;\n        if (option) {\n          if (record_id) {\n            return _deleteRecord(object_name, record_id, record_title, list_view_id, record, function() {\n              var _e, appid, current_object_name, current_record_id, dxDataGridInstance, gridContainer, gridObjectNameClass, isOpenerRemove, recordUrl, ref, tempNavRemoved;\n              gridObjectNameClass = object_name.replace(/\\./g, \"-\");\n              gridContainer = $(\".gridContainer.\" + gridObjectNameClass);\n              if (!(gridContainer != null ? gridContainer.length : void 0)) {\n                if (window.opener) {\n                  isOpenerRemove = false;\n                  gridContainer = window.opener.$(\".gridContainer.\" + gridObjectNameClass);\n                }\n              }\n              try {\n                current_object_name = Session.get(\"object_name\");\n                current_record_id = Session.get(\"record_id\");\n                if (current_object_name && ((ref = Creator.getObject(current_object_name)) != null ? ref.version : void 0) > 1) {\n                  SteedosUI.reloadRecord(current_object_name, current_record_id);\n                }\n                if (FlowRouter.current().route.path.endsWith(\"/:record_id\")) {\n                  if (object_name !== Session.get(\"object_name\")) {\n                    FlowRouter.reload();\n                  }\n                } else {\n                  window.refreshGrid(gridName);\n                }\n              } catch (error1) {\n                _e = error1;\n                console.error(_e);\n              }\n              if (gridContainer != null ? gridContainer.length : void 0) {\n                if (object.enable_tree) {\n                  dxDataGridInstance = gridContainer.dxTreeList().dxTreeList('instance');\n                } else {\n                  dxDataGridInstance = gridContainer.dxDataGrid().dxDataGrid('instance');\n                }\n              }\n              if (dxDataGridInstance) {\n                if (object.enable_tree) {\n                  dxDataGridInstance.refresh();\n                } else {\n                  if (object_name !== Session.get(\"object_name\")) {\n                    FlowRouter.reload();\n                  }\n                }\n              }\n              recordUrl = Creator.getObjectUrl(object_name, record_id);\n              tempNavRemoved = Creator.removeTempNavItem(object_name, recordUrl);\n              if (isOpenerRemove || !dxDataGridInstance) {\n                if (isOpenerRemove) {\n                  window.close();\n                } else if (record_id === Session.get(\"record_id\") && list_view_id !== 'calendar') {\n                  appid = Session.get(\"app_id\");\n                  if (!tempNavRemoved) {\n                    FlowRouter.go(\"/app/\" + appid + \"/\" + object_name + \"/grid/\" + list_view_id);\n                  }\n                }\n              }\n              if (call_back && typeof call_back === \"function\") {\n                return call_back();\n              }\n            });\n          } else {\n            if (selectedRecords && selectedRecords.length) {\n              $(\"body\").addClass(\"loading\");\n              deleteCounter = 0;\n              afterBatchesDelete = function() {\n                deleteCounter++;\n                if (deleteCounter >= selectedRecords.length) {\n                  $(\"body\").removeClass(\"loading\");\n                  return window.refreshGrid(gridName);\n                }\n              };\n              return selectedRecords.forEach(function(record) {\n                var recordTitle;\n                record_id = record._id;\n                beforeHook = FormManager.runHook(object_name, 'delete', 'before', {\n                  _id: record_id\n                });\n                if (!beforeHook) {\n                  afterBatchesDelete();\n                  return;\n                }\n                recordTitle = record[nameField] || record_id;\n                return _deleteRecord(object_name, record._id, recordTitle, list_view_id, record, (function() {\n                  var recordUrl;\n                  recordUrl = Creator.getObjectUrl(object_name, record_id);\n                  Creator.removeTempNavItem(object_name, recordUrl);\n                  return afterBatchesDelete();\n                }), function() {\n                  return afterBatchesDelete();\n                });\n              });\n            }\n          }\n        }\n      });\n    }\n  });\n}\n"]} diff --git a/server/bundle/programs/server/packages/steedos_objects.js.map b/server/bundle/programs/server/packages/steedos_objects.js.map index 398faffbdb..cb0bbea5b4 100644 --- a/server/bundle/programs/server/packages/steedos_objects.js.map +++ b/server/bundle/programs/server/packages/steedos_objects.js.map @@ -1 +1 @@ -{"version":3,"sources":["meteor://💻app/packages/steedos_objects/core.coffee","meteor://💻app/core.coffee","meteor://💻app/packages/steedos_objects/loadStandardObjects.coffee","meteor://💻app/loadStandardObjects.coffee","meteor://💻app/packages/steedos_objects/coreSupport.coffee","meteor://💻app/coreSupport.coffee","meteor://💻app/packages/steedos_objects/server/methods/object_options.coffee","meteor://💻app/server/methods/object_options.coffee","meteor://💻app/packages/steedos_objects/lib/listviews.coffee","meteor://💻app/lib/listviews.coffee","meteor://💻app/packages/steedos_objects/lib/add_simple_schema_validation_error.coffee","meteor://💻app/lib/add_simple_schema_validation_error.coffee","meteor://💻app/packages/steedos_objects/lib/field_simple_schema_validation_error.coffee","meteor://💻app/lib/field_simple_schema_validation_error.coffee","meteor://💻app/packages/steedos:objects/lib/eval.js","meteor://💻app/packages/steedos_objects/lib/convert.coffee","meteor://💻app/lib/convert.coffee","meteor://💻app/packages/steedos_objects/lib/formular.coffee","meteor://💻app/lib/formular.coffee","meteor://💻app/packages/steedos_objects/lib/object.coffee","meteor://💻app/lib/object.coffee","meteor://💻app/packages/steedos_objects/lib/fields.coffee","meteor://💻app/lib/fields.coffee","meteor://💻app/packages/steedos_objects/lib/triggers.coffee","meteor://💻app/lib/triggers.coffee","meteor://💻app/packages/steedos_objects/lib/permission_sets.coffee","meteor://💻app/lib/permission_sets.coffee","meteor://💻app/packages/steedos_objects/lib/collections.coffee","meteor://💻app/lib/collections.coffee","meteor://💻app/packages/steedos_objects/lib/actions.coffee","meteor://💻app/lib/actions.coffee"],"names":["db","Creator","Objects","Collections","Menus","Apps","Dashboards","Reports","subs","steedosSchema","APIService","MetadataService","config","e","moleculer","objectql","packageLoader","packageService","path","settings","steedosCore","process","env","CREATOR_NODE_ENV","require","getSteedosConfig","built_in_plugins","plugins","Meteor","startup","apiService","broker","ex","metadataService","objectqlService","pageService","projectService","standardObjectsDir","standardObjectsPackageLoaderService","steedosService","uiService","ServiceBroker","namespace","nodeID","metadata","transporter","TRANSPORTER","cacher","CACHER","logLevel","serializer","requestTimeout","maxCallLevel","heartbeatInterval","heartbeatTimeout","contextParamsCloning","tracking","enabled","shutdownTimeout","disableBalancer","registry","strategy","preferLocal","bulkhead","concurrency","maxQueueSize","validator","errorHandler","tracing","exporter","type","options","logger","colors","width","gaugeWidth","skipProcessEventRegistration","created","warn","clean","init","createService","name","mixins","port","started","setTimeout","emit","getSteedosSchema","StandardObjectsPath","packageInfo","wrapAsync","cb","start","then","connectHandlersExpress","express","_restartService","use","staticRouter","waitForServices","console","log","SteedosApi","WebApp","connectHandlers","resolve","reject","error","Fiber","deps","app","Tracker","Dependency","object","_TEMPLATE","SimpleSchema","extendOptions","filtersFunction","Match","Optional","OneOf","Function","String","optionsFunction","createFunction","isServer","fiberLoadObjects","obj","object_name","loadObjects","run","list_views","space","getCollectionName","_","clone","convertObject","Object","initTriggers","initListViews","getObjectName","getObject","space_id","ref","ref1","isArray","isClient","depend","Session","get","objectsByName","getObjectById","object_id","findWhere","_id","removeObject","getCollection","spaceId","_collection_name","removeCollection","isSpaceAdmin","userId","findOne","fields","admins","indexOf","evaluateFormula","formular","context","isString","Formular","checkFormula","evaluateFilters","filters","selector","each","filter","action","value","length","isCommonSpace","getOrderlySetByIds","docs","ids","id_key","hit_first","values","getProperty","sortBy","doc","_index","sortingMethod","value1","value2","isValue1Empty","isValue2Empty","locale","key","Date","getTime","Steedos","toString","localeCompare","getObjectRelateds","_object","permissions","relatedList","relatedListMap","related_objects","isEmpty","objName","isObject","objectName","related_object","related_object_name","related_field","related_field_name","reference_to","foreign_key","write_requires_master_read","enableObjName","getPermissions","enable_audit","modifyAllRecords","enable_files","push","sfsFilesObject","splice","enable_tasks","enable_notes","enable_events","enable_instances","enable_approvals","enable_process","getUserContext","isUnSafeMode","USER_CONTEXT","space_user_org","su","suFields","Error","mobile","position","email","company","organization","company_id","company_ids","user","fullname","getRelativeUrl","url","isFunction","isCordova","startsWith","test","__meteor_runtime_config__","ROOT_URL_PATH_PREFIX","getUserCompanyId","getUserCompanyIds","processPermissions","po","allowCreate","allowRead","allowEdit","allowDelete","viewAllRecords","viewCompanyRecords","modifyCompanyRecords","allowReadFiles","viewAllFiles","allowCreateFiles","allowEditFiles","allowDeleteFiles","modifyAllFiles","getTemplateSpaceId","templateSpaceId","getCloudAdminSpaceId","cloudAdminSpaceId","isTemplateSpace","isCloudAdminSpace","steedosStorageDir","STEEDOS_STORAGE_DIR","methods","collection","name_field_key","options_limit","query","query_options","records","results","searchTextQuery","selected","sort","params","NAME_FIELD_KEY","searchText","$regex","$or","$in","extend","$nin","filterQuery","limit","find","fetch","record","label","message","JSON","stringify","getInitWidthPercent","columns","_schema","column_num","init_width_percent","getSchema","field_name","field","is_wide","ref2","pick","autoform","getFieldIsWide","getTabularOrder","list_view_id","setting","record_id","map","column","hidden","compact","order","index","default_extra_columns","extra_columns","getObjectDefaultColumns","getObjectDefaultExtraColumns","union","getObjectDefaultSort","TabularSelectedIds","convertListView","default_view","list_view","list_view_name","default_columns","default_mobile_columns","oitem","mobile_columns","has","include","filter_scope","parse","forEach","_value","getRelatedList","layoutRelatedList","list","mapList","objectLayoutRelatedListObjects","relatedListNames","relatedListObjects","related_object_names","unrelated_objects","related_lists","item","reFieldName","reObjectName","related","related_field_fullname","split","field_names","is_file","customRelatedListObject","actions","buttons","visible_on","page_size","objOrName","getRelatedObjects","related_object_item","relatedObject","tabular_order","getObjectFirstListViewColumns","without","transformSortToTabular","replace","pluck","difference","v","isActive","allow_relatedList","getObjectFirstListView","first","getListViews","getListView","exac","listViews","getListViewIsRecent","listView","pickObjectMobileColumns","count","getField","isNameColumn","itemCount","maxCount","maxRows","nameColumn","nameKey","result","getObjectDefaultView","defaultView","use_mobile_columns","isAllView","isRecentView","tabularColumns","tabular_sort","column_index","transformSortToDX","dx_sort","RegEx","code","RegExp","_regExMessages","_globalMessages","regEx","exp","msg","messages","evalInContext","js","eval","call","convertField","getOption","option","foo","color","allOptions","picklist","picklistOptions","getPicklist","getPickListOptions","reverse","enable","defaultValue","triggers","trigger","_todo","_todo_from_code","_todo_from_db","on","todo","systemBaseFields","omit","required","readonly","getSystemBaseFields","_visible","error1","actionsByName","trim","isExpression","visible","record_permissions","globalData","assign","now","parseSingleExpression","_options","_type","beforeOpenFunction","is_company_limited","max","min","_option","k","_regEx","_min","_max","Number","Boolean","_optionsFunction","_reference_to","_createFunction","_beforeOpenFunction","_filtersFunction","_defaultValue","_is_company_limited","_filters","isDate","pop","_is_date","form","val","relatedObjInfo","PREFIX","_prependPrefixForFormula","prefix","fieldVariable","reg","rev","m","$1","formula_str","_CONTEXT","_VALUES","data","isBoolean","toastr","formatObjectName","_baseObject","_db","defaultListViewId","disabled_list_views","ref3","schema","self","baseObject","permission_set","icon","description","is_view","hasImportTemplates","version","is_enable","allow_customActions","exclude_actions","enable_search","paging","enable_api","custom","enable_share","enable_tree","sidebar","open_window","filter_company","calendar","enable_chatter","enable_trash","enable_space_global","enable_follow","enable_workflow","enable_inline_edit","details","masters","lookup_details","in_development","idFieldName","database_name","is_name","primary","filterable","item_name","copyItem","admin","all","list_view_item","ReactiveVar","createCollection","_name","getObjectSchema","contains","attachSchema","_simpleSchema","getObjectODataRouterPrefix","bootstrapLoaded","getSelectOptions","fieldSchema","data_type","optionItem","fieldsArr","_ref_obj","autoform_type","collectionName","fs","fsType","isUnLimited","multiple","rows","language","isMobile","isPad","isiOS","afFieldInput","timezoneId","dxDateBoxOptions","displayFormat","pickerType","dateMobileOptions","outFormat","showIcon","dependOn","depend_on","create","lookup_field","Modal","show","formId","operation","onSuccess","addItems","reference_sort","optionsSort","reference_limit","optionsLimit","reference_to_field","referenceToField","blackbox","objectSwitche","optionsMethod","optionsMethodParams","references","_reference","link","defaultIcon","firstOption","decimal","precision","scale","disabled","Array","editable","accept","system","Email","isNumber","optional","unique","group","searchable","inlineHelpText","isProduction","sortable","getFieldDisplayValue","field_value","html","moment","format","checkFieldTypeSupportBetweenQuery","field_type","includes","pushBetweenBuiltinOptionals","operations","builtinValues","getBetweenBuiltinValues","builtinItem","is_check_only","getBetweenTimeBuiltinValues","getBetweenBuiltinValueItem","getBetweenTimeBuiltinValueItem","getBetweenBuiltinOperation","betweenBuiltinValues","getQuarterStartMonth","month","getMonth","getLastQuarterFirstDay","year","getFullYear","getNextQuarterFirstDay","getMonthDays","days","endDate","millisecond","startDate","getLastMonthFirstDay","currentMonth","currentYear","endValue","firstDay","lastDay","lastMonday","lastMonthFinalDay","lastMonthFirstDay","lastQuarterEndDay","lastQuarterStartDay","lastSunday","last_120_days","last_30_days","last_60_days","last_7_days","last_90_days","minusDay","monday","nextMonday","nextMonthFinalDay","nextMonthFirstDay","nextQuarterEndDay","nextQuarterStartDay","nextSunday","nextYear","next_120_days","next_30_days","next_60_days","next_7_days","next_90_days","previousYear","startValue","strEndDay","strFirstDay","strLastDay","strMonday","strStartDay","strSunday","strToday","strTomorrow","strYestday","sunday","thisQuarterEndDay","thisQuarterStartDay","tomorrow","week","yestday","getDay","t","fv","setHours","getHours","getTimezoneOffset","getFieldDefaultOperation","getFieldOperation","optionals","equal","unequal","less_than","greater_than","less_or_equal","greater_or_equal","not_contain","starts_with","between","getObjectFieldsName","fieldsName","sort_no","cleanTrigger","initTrigger","_trigger_hooks","ref4","ref5","todoWrapper","apply","arguments","when","before","insert","update","remove","after","_hook","trigger_name","_trigger_hook","baseBooleanPermissionPropNames","extendPermissionProps","findOne_permission_object","find_permission_object","intersectionPlus","otherPermissionPropNames","overlayBaseBooleanPermissionProps","permissionPropNames","unionPermissionObjects","unionPlus","getObjectPermissions","getRecordPermissions","isOwner","masterObjectName","masterRecordPerm","record_company_id","record_company_ids","user_company_ids","owner","parent","n","intersection","locked","getRecordRelatedListPermissions","currentObjectName","relatedListItem","currentRecord","isRelateObjectUneditable","masterAllow","relatedObjectPermissions","uneditable_related_list","getObjectRecord","getRecordSafeRelatedList","getAllPermissions","_i","psets","psetsAdmin","psetsAdmin_pos","psetsCurrent","psetsCurrentNames","psetsCurrent_pos","psetsCustomer","psetsCustomer_pos","psetsGuest","psetsGuest_pos","psetsMember","psetsMember_pos","psetsSupplier","psetsSupplier_pos","psetsUser","psetsUser_pos","set_ids","spaceUser","objects","assigned_apps","profile","users","permission_set_id","modified","created_by","modified_by","getAssignedApps","bind","assigned_menus","getAssignedMenus","user_permission_sets","array","other","target","props","filesProNames","propNames","propName","apps","psetBase","userProfile","pset","uniq","aboutMenu","adminMenus","allMenus","currentPsetNames","menus","otherMenuApps","otherMenus","admin_menus","flatten","menu","psetsMenu","permission_sets","permission_objects","isNull","permission_set_ids","pos","ops","ops_key","currentPset","tempOps","repeatIndex","repeatPo","opsetAdmin","opsetCustomer","opsetGuest","opsetMember","opsetSupplier","opsetUser","posAdmin","posCustomer","posGuest","posMember","posSupplier","posUser","prof","guest","member","supplier","customer","disabled_actions","unreadable_fields","uneditable_fields","creator_db_url","oplog_url","MONGO_URL_CREATOR","MONGO_OPLOG_URL_CREATOR","_CREATOR_DATASOURCE","_driver","MongoInternals","RemoteCollectionDriver","oplogUrl","collection_key","newCollection","SMSQueue","_deleteRecord","action_name","executeAction","item_element","callback","moreArgs","todoArgs","ObjectGrid","getFilters","word_template","SteedosFilters","formatFiltersToODataQuery","absoluteUrl","window","open","odata","prototype","slice","concat","warning","record_title","call_back","call_back_error","previousDoc","FormManager","getPreviousDoc","info","success","runHook","relatedObjectStandardNew","collection_name","current_object_name","current_record_id","defaultDoc","initialValues","relateObject","set","getRelatedInitialValues","SteedosUI","showModal","stores","ComponentRegistry","components","ObjectForm","objectApiName","title","afterInsert","reloadRecord","FlowRouter","reload","iconPath","defer","$","click","gridName","isRelated","masterRecordId","relatedFieldName","selectedRows","gridRefs","current","api","getSelectedRows","gridRef","getInitialValues","Page","Form","StandardNew","render","href","getObjectUrl","redirect","StandardEdit","beforeHook","i18nTextKey","i18nTitleKey","nameField","selectedRecords","text","getTableSelectedRows","swal","showCancelButton","confirmButtonText","cancelButtonText","afterBatchesDelete","deleteCounter","_e","appid","dxDataGridInstance","gridContainer","gridObjectNameClass","isOpenerRemove","recordUrl","tempNavRemoved","opener","route","endsWith","refreshGrid","dxTreeList","dxDataGrid","refresh","removeTempNavItem","close","go","addClass","removeClass","recordTitle"],"mappings":"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","file":"/packages/steedos_objects.js","sourcesContent":["@db = {}\nif !Creator?\n\t@Creator = {}\nCreator.Objects = {}\nCreator.Collections = {}\nCreator.Menus = []\nCreator.Apps = {}\nCreator.Dashboards = {}\nCreator.Reports = {}\nCreator.subs = {}\nCreator.steedosSchema = {}","this.db = {};\n\nif (typeof Creator === \"undefined\" || Creator === null) {\n this.Creator = {};\n}\n\nCreator.Objects = {};\n\nCreator.Collections = {};\n\nCreator.Menus = [];\n\nCreator.Apps = {};\n\nCreator.Dashboards = {};\n\nCreator.Reports = {};\n\nCreator.subs = {};\n\nCreator.steedosSchema = {};\n","try\n\tif process.env.CREATOR_NODE_ENV == 'development'\n\t\tsteedosCore = require('@steedos/core')\n\t\tobjectql = require('@steedos/objectql')\n\t\tmoleculer = require(\"moleculer\");\n\t\tpackageLoader = require('@steedos/service-meteor-package-loader');\n\t\tAPIService = require('@steedos/service-api');\n\t\tMetadataService = require('@steedos/service-metadata-server');\n\t\tpackageService = require(\"@steedos/service-package-registry\");\n\t\tpath = require('path')\n\n\t\tconfig = objectql.getSteedosConfig();\n\t\tsettings = {\n\t\t\tbuilt_in_plugins: [\n\t\t\t\t\"@steedos/standard-space\",\n\t\t\t\t\"@steedos/standard-object-database\",\n\t\t\t\t\"@steedos/standard-process-approval\",\n\t\t\t\t\"@steedos/standard-collaboration\",\n\t\t\t\t\"@steedos/standard-ui\",\n\t\t\t\t\"@steedos/standard-permission\",\n\t\t\t\t\"@steedos/webapp-public\",\n\t\t\t\t\"@steedos/service-cachers-manager\",\n\t\t\t\t\"@steedos/unpkg\",\n\t\t\t\t\"@steedos/workflow\",\n\t\t\t\t\"@steedos/accounts\",\n\t\t\t\t\"@steedos/plugin-company\",\n\t\t\t\t\"@steedos/metadata-api\",\n\t\t\t\t\"@steedos/data-import\",\n\t\t\t\t# \"@steedos/service-fields-indexs\",\n\t\t\t\t\"@steedos/service-accounts\",\n\t\t\t\t\"@steedos/service-charts\",\n\t\t\t\t# \"@steedos/service-pages\",\n\t\t\t\t\"@steedos/service-package-registry\",\n\t\t \t\t\"@steedos/service-package-tool\",\n\t\t\t\t# \"@steedos/standard-process\",\n\t\t\t\t\"@steedos/webapp-accounts\",\n\t\t\t\t\"@steedos/service-workflow\",\n\t\t\t\t\"@steedos/service-plugin-amis\",\n\t\t\t\t\"@steedos/service-files\",\n\t\t\t\t\"@steedos/service-sentry\",\n\t\t\t\t\"@steedos/service-identity-jwt\"\n\t\t\t],\n\t\t\tplugins: config.plugins\n\t\t}\n\t\tMeteor.startup ->\n\t\t\ttry\n\t\t\t\tbroker = new moleculer.ServiceBroker({\n\t\t\t\t\tnamespace: \"steedos\",\n\t\t\t\t\tnodeID: \"steedos-creator\",\n\t\t\t\t\tmetadata: {},\n\t\t\t\t\ttransporter: process.env.TRANSPORTER,\n\t\t\t\t\tcacher: process.env.CACHER,\n\t\t\t\t\tlogLevel: \"warn\",\n\t\t\t\t\tserializer: \"JSON\",\n\t\t\t\t\trequestTimeout: 60 * 1000,\n\t\t\t\t\tmaxCallLevel: 100,\n\n\t\t\t\t\theartbeatInterval: 10,\n\t\t\t\t\theartbeatTimeout: 30,\n\n\t\t\t\t\tcontextParamsCloning: false,\n\n\t\t\t\t\ttracking: {\n\t\t\t\t\t\tenabled: false,\n\t\t\t\t\t\tshutdownTimeout: 5000,\n\t\t\t\t\t},\n\n\t\t\t\t\tdisableBalancer: false,\n\n\t\t\t\t\tregistry: {\n\t\t\t\t\t\tstrategy: \"RoundRobin\",\n\t\t\t\t\t\tpreferLocal: true\n\t\t\t\t\t},\n\n\t\t\t\t\tbulkhead: {\n\t\t\t\t\t\tenabled: false,\n\t\t\t\t\t\tconcurrency: 10,\n\t\t\t\t\t\tmaxQueueSize: 100,\n\t\t\t\t\t},\n\t\t\t\t\tvalidator: true,\n\t\t\t\t\terrorHandler: null,\n\t\t\t\t\ttracing: {\n\t\t\t\t\t\tenabled: false,\n\t\t\t\t\t\texporter: {\n\t\t\t\t\t\t\ttype: \"Console\",\n\t\t\t\t\t\t\toptions: {\n\t\t\t\t\t\t\t\tlogger: null,\n\t\t\t\t\t\t\t\tcolors: true,\n\t\t\t\t\t\t\t\twidth: 100,\n\t\t\t\t\t\t\t\tgaugeWidth: 40\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t\tskipProcessEventRegistration: true,\n\n\t\t\t\t\tcreated: (broker)-> \n\t\t\t\t\t\t# Clear all cache entries\n\t\t\t\t\t\tbroker.logger.warn('Clear all cache entries on startup.')\n\t\t\t\t\t\tbroker.cacher.clean();\n\t\t\t\t});\n\n\t\t\t\tobjectql.broker.init(broker);\n\n\t\t\t\tobjectqlService = broker.createService(require(\"@steedos/service-objectql\"));\n\t\t\t\t\n\t\t\t\tprojectService = broker.createService({\n\t\t\t\t\tname: \"project-server\",\n\t\t\t\t\tnamespace: \"steedos\",\n\t\t\t\t\tmixins: [packageService],\n\t\t\t\t});\n\n\n\t\t\t\tmetadataService = broker.createService({\n\t\t\t\t\tname: 'metadata-server',\n\t\t\t\t\tmixins: [MetadataService],\n\t\t\t\t\tsettings: {\n\t\t\t\t\t} \n\t\t\t\t});\n\n\t\t\t\tuiService = broker.createService(require(\"@steedos/service-ui\"));\n\n\t\t\t\tapiService = broker.createService({\n\t\t\t\t\tname: \"api\",\n\t\t\t\t\tmixins: [APIService],\n\t\t\t\t\tsettings: {\n\t\t\t\t\t\tport: null\n\t\t\t\t\t} \n\t\t\t\t});\n\n\t\t\t\tpageService = broker.createService({\n\t\t\t\t\tname: \"@steedos/service-pages\",\n\t\t\t\t\tmixins: [require('@steedos/service-pages')],\n\t\t\t\t\tsettings: {\n\t\t\t\t\t\tport: null\n\t\t\t\t\t} \n\t\t\t\t});\n\n\t\t\t\tsteedosService = broker.createService({\n\t\t\t\t\tname: \"steedos-server\",\n\t\t\t\t\tmixins: [],\n\t\t\t\t\tsettings: {\n\t\t\t\t\t\tport: null\n\t\t\t\t\t},\n\t\t\t\t\tstarted: ()->\n\t\t\t\t\t\tsetTimeout ->\n\t\t\t\t\t\t\tbroker.emit 'steedos-server.started'\n\t\t\t\t\t\t\treturn\n\t\t\t\t\t\t, 1000\n\t\t\t\t});\n\n\t\t\t\tobjectql.getSteedosSchema(broker);\n\t\t\t\tstandardObjectsDir = objectql.StandardObjectsPath;\n\t\t\t\tstandardObjectsPackageLoaderService = broker.createService({\n\t\t\t\t\tname: 'standard-objects',\n\t\t\t\t\tmixins: [packageLoader],\n\t\t\t\t\tsettings: { packageInfo: {\n\t\t\t\t\t\tpath: standardObjectsDir,\n\t\t\t\t\t} }\n\t\t\t\t});\n\n\t\t\t\tMeteor.wrapAsync((cb)->\n\t\t\t\t\tbroker.start().then(()->\n\t\t\t\t\t\tif !broker.started \n\t\t\t\t\t\t\tbroker._restartService(objectqlService);\n\t\t\t\t\t\t\tbroker._restartService(standardObjectsPackageLoaderService);\n\t\t\t\t\t\t\tbroker._restartService(uiService);\n\n\t\t\t\t\t\texpress = require('express');\n\t\t\t\t\t\tconnectHandlersExpress = express();\n\t\t\t\t\t\tconnectHandlersExpress.use(require('@steedos/router').staticRouter());\n\t\t\t\t\t\tbroker.waitForServices('~packages-@steedos/service-ui').then ()->\n\t\t\t\t\t\t\tconsole.log('waitForServices ~packages-@steedos/service-ui')\n\t\t\t\t\t\t\tconnectHandlersExpress.use(SteedosApi.express())\n\t\t\t\t\t\t\tWebApp.connectHandlers.use(connectHandlersExpress)\n\t\t\t\t\t\t\n\t\t\t\t\t\t# steedosCore.init(settings).then ()->\n\t\t\t\t\t\t# \tcb();\n\n\t\t\t\t\t\tbroker.waitForServices(standardObjectsPackageLoaderService.name).then (resolve, reject) ->\n\t\t\t\t\t\t\tsteedosCore.init(settings).then ()->\n\t\t\t\t\t\t\t\tcb(reject, resolve)\n\t\t\t\t\t)\n\t\t\t\t)()\n\t\t\tcatch ex\n\t\t\t\tconsole.error(\"error:\",ex)\ncatch e\n\tconsole.error(\"error:\",e)","var APIService, MetadataService, config, e, moleculer, objectql, packageLoader, packageService, path, settings, steedosCore;\n\ntry {\n if (process.env.CREATOR_NODE_ENV === 'development') {\n steedosCore = require('@steedos/core');\n objectql = require('@steedos/objectql');\n moleculer = require(\"moleculer\");\n packageLoader = require('@steedos/service-meteor-package-loader');\n APIService = require('@steedos/service-api');\n MetadataService = require('@steedos/service-metadata-server');\n packageService = require(\"@steedos/service-package-registry\");\n path = require('path');\n config = objectql.getSteedosConfig();\n settings = {\n built_in_plugins: [\"@steedos/standard-space\", \"@steedos/standard-object-database\", \"@steedos/standard-process-approval\", \"@steedos/standard-collaboration\", \"@steedos/standard-ui\", \"@steedos/standard-permission\", \"@steedos/webapp-public\", \"@steedos/service-cachers-manager\", \"@steedos/unpkg\", \"@steedos/workflow\", \"@steedos/accounts\", \"@steedos/plugin-company\", \"@steedos/metadata-api\", \"@steedos/data-import\", \"@steedos/service-accounts\", \"@steedos/service-charts\", \"@steedos/service-package-registry\", \"@steedos/service-package-tool\", \"@steedos/webapp-accounts\", \"@steedos/service-workflow\", \"@steedos/service-plugin-amis\", \"@steedos/service-files\", \"@steedos/service-sentry\", \"@steedos/service-identity-jwt\"],\n plugins: config.plugins\n };\n Meteor.startup(function() {\n var apiService, broker, ex, metadataService, objectqlService, pageService, projectService, standardObjectsDir, standardObjectsPackageLoaderService, steedosService, uiService;\n try {\n broker = new moleculer.ServiceBroker({\n namespace: \"steedos\",\n nodeID: \"steedos-creator\",\n metadata: {},\n transporter: process.env.TRANSPORTER,\n cacher: process.env.CACHER,\n logLevel: \"warn\",\n serializer: \"JSON\",\n requestTimeout: 60 * 1000,\n maxCallLevel: 100,\n heartbeatInterval: 10,\n heartbeatTimeout: 30,\n contextParamsCloning: false,\n tracking: {\n enabled: false,\n shutdownTimeout: 5000\n },\n disableBalancer: false,\n registry: {\n strategy: \"RoundRobin\",\n preferLocal: true\n },\n bulkhead: {\n enabled: false,\n concurrency: 10,\n maxQueueSize: 100\n },\n validator: true,\n errorHandler: null,\n tracing: {\n enabled: false,\n exporter: {\n type: \"Console\",\n options: {\n logger: null,\n colors: true,\n width: 100,\n gaugeWidth: 40\n }\n }\n },\n skipProcessEventRegistration: true,\n created: function(broker) {\n broker.logger.warn('Clear all cache entries on startup.');\n return broker.cacher.clean();\n }\n });\n objectql.broker.init(broker);\n objectqlService = broker.createService(require(\"@steedos/service-objectql\"));\n projectService = broker.createService({\n name: \"project-server\",\n namespace: \"steedos\",\n mixins: [packageService]\n });\n metadataService = broker.createService({\n name: 'metadata-server',\n mixins: [MetadataService],\n settings: {}\n });\n uiService = broker.createService(require(\"@steedos/service-ui\"));\n apiService = broker.createService({\n name: \"api\",\n mixins: [APIService],\n settings: {\n port: null\n }\n });\n pageService = broker.createService({\n name: \"@steedos/service-pages\",\n mixins: [require('@steedos/service-pages')],\n settings: {\n port: null\n }\n });\n steedosService = broker.createService({\n name: \"steedos-server\",\n mixins: [],\n settings: {\n port: null\n },\n started: function() {\n return setTimeout(function() {\n broker.emit('steedos-server.started');\n }, 1000);\n }\n });\n objectql.getSteedosSchema(broker);\n standardObjectsDir = objectql.StandardObjectsPath;\n standardObjectsPackageLoaderService = broker.createService({\n name: 'standard-objects',\n mixins: [packageLoader],\n settings: {\n packageInfo: {\n path: standardObjectsDir\n }\n }\n });\n return Meteor.wrapAsync(function(cb) {\n return broker.start().then(function() {\n var connectHandlersExpress, express;\n if (!broker.started) {\n broker._restartService(objectqlService);\n broker._restartService(standardObjectsPackageLoaderService);\n broker._restartService(uiService);\n }\n express = require('express');\n connectHandlersExpress = express();\n connectHandlersExpress.use(require('@steedos/router').staticRouter());\n broker.waitForServices('~packages-@steedos/service-ui').then(function() {\n console.log('waitForServices ~packages-@steedos/service-ui');\n connectHandlersExpress.use(SteedosApi.express());\n return WebApp.connectHandlers.use(connectHandlersExpress);\n });\n return broker.waitForServices(standardObjectsPackageLoaderService.name).then(function(resolve, reject) {\n return steedosCore.init(settings).then(function() {\n return cb(reject, resolve);\n });\n });\n });\n })();\n } catch (error) {\n ex = error;\n return console.error(\"error:\", ex);\n }\n });\n }\n} catch (error) {\n e = error;\n console.error(\"error:\", e);\n}\n","Creator.deps = {\n\tapp: new Tracker.Dependency\n\tobject: new Tracker.Dependency\n};\n\nCreator._TEMPLATE = {\n\tApps: {},\n\tObjects: {}\n}\n\nMeteor.startup ->\n\tSimpleSchema.extendOptions({filtersFunction: Match.Optional(Match.OneOf(Function, String))})\n\tSimpleSchema.extendOptions({optionsFunction: Match.Optional(Match.OneOf(Function, String))})\n\tSimpleSchema.extendOptions({createFunction: Match.Optional(Match.OneOf(Function, String))})\n\n# Creator.fiberLoadObjects 供steedos-cli项目使用\nif Meteor.isServer\n\tFiber = require('fibers')\n\tCreator.fiberLoadObjects = (obj, object_name)->\n\t\tFiber(()->\n\t\t\tCreator.loadObjects(obj, object_name)\n\t\t).run()\n\nCreator.loadObjects = (obj, object_name)->\n\tif !object_name\n\t\tobject_name = obj.name\n\n\tif !obj.list_views\n\t\tobj.list_views = {}\n\n\tif obj.space\n\t\tobject_name = Creator.getCollectionName(obj)\n\tif object_name == 'cfs_files_filerecord'\n\t\tobject_name = 'cfs.files.filerecord'\n\t\tobj = _.clone(obj)\n\t\tobj.name = object_name\n\t\tCreator.Objects[object_name] = obj\n\n\tCreator.convertObject(obj)\n\tnew Creator.Object(obj);\n\n\tCreator.initTriggers(object_name)\n\tCreator.initListViews(object_name)\n\treturn obj\n\nCreator.getObjectName = (object) ->\n\tif object.space\n\t\treturn \"c_#{object.space}_#{object.name}\"\n\treturn object.name\n\nCreator.getObject = (object_name, space_id)->\n\tif _.isArray(object_name)\n\t\treturn ;\n\tif Meteor.isClient\n\t\tCreator.deps?.object?.depend()\n\tif !object_name and Meteor.isClient\n\t\tobject_name = Session.get(\"object_name\")\n\n#\tif !space_id && object_name\n#\t\tif Meteor.isClient && !object_name.startsWith('c_')\n#\t\t\tspace_id = Session.get(\"spaceId\")\n\n\tif object_name\n#\t\tif space_id\n#\t\t\tobj = Creator.objectsByName[\"c_#{space_id}_#{object_name}\"]\n#\t\t\tif obj\n#\t\t\t\treturn obj\n#\n#\t\tobj = _.find Creator.objectsByName, (o)->\n#\t\t\t\treturn o._collection_name == object_name\n#\t\tif obj\n#\t\t\treturn obj\n\n\t\treturn Creator.objectsByName[object_name]\n\nCreator.getObjectById = (object_id)->\n\treturn _.findWhere(Creator.objectsByName, {_id: object_id})\n\nCreator.removeObject = (object_name)->\n\tconsole.log(\"removeObject\", object_name)\n\tdelete Creator.Objects[object_name]\n\tdelete Creator.objectsByName[object_name]\n\nCreator.getCollection = (object_name, spaceId)->\n\tif !object_name\n\t\tobject_name = Session.get(\"object_name\")\n\tif object_name\n\t\tif Meteor.isClient\n\t\t\treturn db[object_name]\n\t\telse\n\t\t\treturn Creator.Collections[Creator.getObject(object_name, spaceId)?._collection_name || object_name]\n\nCreator.removeCollection = (object_name)->\n\tdelete Creator.Collections[object_name]\n\nCreator.isSpaceAdmin = (spaceId, userId)->\n\tif Meteor.isClient\n\t\tif !spaceId\n\t\t\tspaceId = Session.get(\"spaceId\")\n\t\tif !userId\n\t\t\tuserId = Meteor.userId()\n\n\tspace = Creator.getObject(\"spaces\")?.db?.findOne(spaceId,{fields:{admins:1}})\n\tif space?.admins\n\t\treturn space.admins.indexOf(userId) >= 0\n\n\nCreator.evaluateFormula = (formular, context, options)->\n\n\tif !_.isString(formular)\n\t\treturn formular\n\n\tif Creator.Formular.checkFormula(formular)\n\t\treturn Creator.Formular.run(formular, context, options)\n\n\treturn formular\n\nCreator.evaluateFilters = (filters, context)->\n\tselector = {}\n\t_.each filters, (filter)->\n\t\tif filter?.length == 3\n\t\t\tname = filter[0]\n\t\t\taction = filter[1]\n\t\t\tvalue = Creator.evaluateFormula(filter[2], context)\n\t\t\tselector[name] = {}\n\t\t\tselector[name][action] = value\n\t# console.log(\"evaluateFilters-->selector\", selector)\n\treturn selector\n\nCreator.isCommonSpace = (spaceId) ->\n\treturn spaceId == 'common'\n\n###\n\tdocs:待排序的文档数组\n\tids:_id集合\n\tid_key: 默认为_id\n\treturn 按照ids的顺序返回新的文档集合\n###\nCreator.getOrderlySetByIds = (docs, ids, id_key, hit_first)->\n\n\tif !id_key\n\t\tid_key = \"_id\"\n\n\tif hit_first\n\n\t\t#由于不能使用_.findIndex函数,因此此处先将对象数组转为普通数组类型,在获取其index\n\t\tvalues = docs.getProperty(id_key)\n\n\t\treturn\t_.sortBy docs, (doc)->\n\t\t\t\t\t_index = ids.indexOf(doc[id_key])\n\t\t\t\t\tif _index > -1\n\t\t\t\t\t\treturn _index\n\t\t\t\t\telse\n\t\t\t\t\t\treturn ids.length + _.indexOf(values, doc[id_key])\n\telse\n\t\treturn\t_.sortBy docs, (doc)->\n\t\t\treturn ids.indexOf(doc[id_key])\n\n###\n\t按用户所属本地化语言进行排序,支持中文、数值、日期等字段排序\n\t对于Object类型,如果提供作用域中key属性,则取值为value[key]进行排序比较,反之整个Object.toString()后排序比较\n###\nCreator.sortingMethod = (value1, value2) ->\n\tif this.key\n\t\tvalue1 = value1[this.key]\n\t\tvalue2 = value2[this.key]\n\tif value1 instanceof Date\n\t\tvalue1 = value1.getTime()\n\tif value2 instanceof Date\n\t\tvalue2 = value2.getTime()\n\tif typeof value1 is \"number\" and typeof value2 is \"number\"\n\t\treturn value1 - value2\n\t# Handling null values\n\tisValue1Empty = value1 == null or value1 == undefined\n\tisValue2Empty = value2 == null or value2 == undefined\n\tif isValue1Empty and !isValue2Empty\n\t\treturn -1\n\tif isValue1Empty and isValue2Empty\n\t\treturn 0\n\tif !isValue1Empty and isValue2Empty\n\t\treturn 1\n\tlocale = Steedos.locale()\n\treturn value1.toString().localeCompare value2.toString(), locale\n\n\n# 该函数只在初始化Object时,把相关对象的计算结果保存到Object的related_objects属性中,后续可以直接从related_objects属性中取得计算结果而不用再次调用该函数来计算\nCreator.getObjectRelateds = (object_name)->\n\tif Meteor.isClient\n\t\tif !object_name\n\t\t\tobject_name = Session.get(\"object_name\")\n\n\trelated_objects = []\n\t# _object = Creator.getObject(object_name)\n\t# 因Creator.getObject函数内部要调用该函数,所以这里不可以调用Creator.getObject取对象,只能调用Creator.Objects来取对象\n\t_object = Creator.Objects[object_name]\n\tif !_object\n\t\treturn related_objects\n\t\n\trelatedList = _object.relatedList\n\tif Meteor.isClient && !_.isEmpty relatedList\n\t\trelatedListMap = {}\n\t\t_.each relatedList, (objName)->\n\t\t\tif _.isObject objName\n\t\t\t\trelatedListMap[objName.objectName] = {}\n\t\t\telse\n\t\t\t\trelatedListMap[objName] = {}\n\t\t_.each Creator.Objects, (related_object, related_object_name)->\n\t\t\t_.each related_object.fields, (related_field, related_field_name)->\n\t\t\t\tif (related_field.type == \"master_detail\" || related_field.type == \"lookup\") and related_field.reference_to and related_field.reference_to == object_name and relatedListMap[related_object_name]\n\t\t\t\t\t# 当related_object.fields中有两个或以上的字段指向object_name表示的对象时,优先取第一个作为外键关系字段,但是related_field为主子表时强行覆盖之前的relatedListMap[related_object_name]值\n\t\t\t\t\tif _.isEmpty relatedListMap[related_object_name] || related_field.type == \"master_detail\"\n\t\t\t\t\t\trelatedListMap[related_object_name] = { object_name: related_object_name, foreign_key: related_field_name, write_requires_master_read: related_field.write_requires_master_read }\n\t\tif relatedListMap['cms_files']\n\t\t\trelatedListMap['cms_files'] = { object_name: \"cms_files\", foreign_key: \"parent\" }\n\t\tif relatedListMap['instances']\n\t\t\trelatedListMap['instances'] = { object_name: \"instances\", foreign_key: \"record_ids\" }\n\t\t_.each ['tasks', 'notes', 'events', 'approvals'], (enableObjName)->\n\t\t\tif relatedListMap[enableObjName]\n\t\t\t\trelatedListMap[enableObjName] = { object_name: enableObjName, foreign_key: \"related_to\" }\n\t\tif relatedListMap['audit_records']\n\t\t\t#record 详细下的audit_records仅modifyAllRecords权限可见\n\t\t\tpermissions = Creator.getPermissions(object_name)\n\t\t\tif _object.enable_audit && permissions?.modifyAllRecords\n\t\t\t\trelatedListMap['audit_records'] = { object_name:\"audit_records\", foreign_key: \"related_to\" }\n\t\trelated_objects = _.values relatedListMap\n\t\treturn related_objects\n\n\tif _object.enable_files\n\t\trelated_objects.push {object_name:\"cms_files\", foreign_key: \"parent\"}\n\n\t_.each Creator.Objects, (related_object, related_object_name)->\n\t\tif related_object_name == \"cfs.files.filerecord\"\n\t\t\t# cfs.files.filerecord对象在第二次点击的时候related_object返回的是app-builder中的\"metadata.parent\"字段被删除了,记到metadata字段的sub_fields中了,所以要单独处理。\n\t\t\tsfsFilesObject = Creator.getObject(\"cfs.files.filerecord\")\n\t\t\tsfsFilesObject && related_object = sfsFilesObject\n\t\t_.each related_object.fields, (related_field, related_field_name)->\n\t\t\tif (related_field.type == \"master_detail\" || (related_field.type == \"lookup\" && related_field.relatedList)) and related_field.reference_to and related_field.reference_to == object_name\n\t\t\t\tif related_object_name == \"object_fields\"\n\t\t\t\t\t#TODO 待相关列表支持排序后,删除此判断\n\t\t\t\t\trelated_objects.splice(0, 0, {object_name:related_object_name, foreign_key: related_field_name})\n\t\t\t\telse\n\t\t\t\t\trelated_objects.push {object_name:related_object_name, foreign_key: related_field_name, write_requires_master_read: related_field.write_requires_master_read}\n\n\tif _object.enable_tasks\n\t\trelated_objects.push {object_name:\"tasks\", foreign_key: \"related_to\"}\n\tif _object.enable_notes\n\t\trelated_objects.push {object_name:\"notes\", foreign_key: \"related_to\"}\n\tif _object.enable_events\n\t\trelated_objects.push {object_name:\"events\", foreign_key: \"related_to\"}\n\tif _object.enable_instances\n\t\trelated_objects.push {object_name:\"instances\", foreign_key: \"record_ids\"}\n\tif _object.enable_approvals\n\t\trelated_objects.push {object_name:\"approvals\", foreign_key: \"related_to\"}\n\tif _object.enable_process\n\t\trelated_objects.push {object_name:\"process_instance_history\", foreign_key: \"target_object\"}\n\t#record 详细下的audit_records仅modifyAllRecords权限可见\n\tif Meteor.isClient\n\t\tpermissions = Creator.getPermissions(object_name)\n\t\tif _object.enable_audit && permissions?.modifyAllRecords\n\t\t\trelated_objects.push {object_name:\"audit_records\", foreign_key: \"related_to\"}\n\n\treturn related_objects\n\nCreator.getUserContext = (userId, spaceId, isUnSafeMode)->\n\tif Meteor.isClient\n\t\treturn Creator.USER_CONTEXT\n\telse\n\t\tif !(userId and spaceId)\n\t\t\tthrow new Meteor.Error 500, \"the params userId and spaceId is required for the function Creator.getUserContext\"\n\t\t\treturn null\n\t\tsuFields = {name: 1, mobile: 1, position: 1, email: 1, company: 1, organization: 1, space: 1, company_id: 1, company_ids: 1}\n\t\t# check if user in the space\n\t\tsu = Creator.Collections[\"space_users\"].findOne({space: spaceId, user: userId}, {fields: suFields})\n\t\tif !su\n\t\t\tspaceId = null\n\n\t\t# if spaceId not exists, get the first one.\n\t\tif !spaceId\n\t\t\tif isUnSafeMode\n\t\t\t\tsu = Creator.Collections[\"space_users\"].findOne({user: userId}, {fields: suFields})\n\t\t\t\tif !su\n\t\t\t\t\treturn null\n\t\t\t\tspaceId = su.space\n\t\t\telse\n\t\t\t\treturn null\n\n\t\tUSER_CONTEXT = {}\n\t\tUSER_CONTEXT.userId = userId\n\t\tUSER_CONTEXT.spaceId = spaceId\n\t\tUSER_CONTEXT.user = {\n\t\t\t_id: userId\n\t\t\tname: su.name,\n\t\t\tmobile: su.mobile,\n\t\t\tposition: su.position,\n\t\t\temail: su.email\n\t\t\tcompany: su.company\n\t\t\tcompany_id: su.company_id\n\t\t\tcompany_ids: su.company_ids\n\t\t}\n\t\tspace_user_org = Creator.getCollection(\"organizations\")?.findOne(su.organization)\n\t\tif space_user_org\n\t\t\tUSER_CONTEXT.user.organization = {\n\t\t\t\t_id: space_user_org._id,\n\t\t\t\tname: space_user_org.name,\n\t\t\t\tfullname: space_user_org.fullname\n\t\t\t}\n\t\treturn USER_CONTEXT\n\nCreator.getRelativeUrl = (url)->\n\n\tif _.isFunction(Steedos.isCordova) && Steedos.isCordova() && (url?.startsWith(\"/assets\") || url?.startsWith(\"assets\") || url?.startsWith(\"/packages\"))\n\t\tif !/^\\//.test(url)\n\t\t\turl = \"/\" + url\n\t\treturn url\n\n\tif url\n\t\t# url开头没有\"/\",需要添加\"/\"\n\t\tif !/^\\//.test(url)\n\t\t\turl = \"/\" + url\n\t\treturn __meteor_runtime_config__.ROOT_URL_PATH_PREFIX + url\n\telse\n\t\treturn __meteor_runtime_config__.ROOT_URL_PATH_PREFIX\n\nCreator.getUserCompanyId = (userId, spaceId)->\n\tuserId = userId || Meteor.userId()\n\tif Meteor.isClient\n\t\tspaceId = spaceId || Session.get('spaceId')\n\telse\n\t\tif !spaceId\n\t\t\tthrow new Meteor.Error(400, 'miss spaceId')\n\tsu = Creator.getCollection('space_users').findOne({space: spaceId, user: userId}, {fields: {company_id:1}})\n\treturn su.company_id\n\nCreator.getUserCompanyIds = (userId, spaceId)->\n\tuserId = userId || Meteor.userId()\n\tif Meteor.isClient\n\t\tspaceId = spaceId || Session.get('spaceId')\n\telse\n\t\tif !spaceId\n\t\t\tthrow new Meteor.Error(400, 'miss spaceId')\n\tsu = Creator.getCollection('space_users').findOne({space: spaceId, user: userId}, {fields: {company_ids:1}})\n\treturn su?.company_ids\n\nCreator.processPermissions = (po)->\n\tif po.allowCreate\n\t\tpo.allowRead = true\n\tif po.allowEdit\n\t\tpo.allowRead = true\n\tif po.allowDelete\n\t\tpo.allowEdit = true\n\t\tpo.allowRead = true\n\tif po.viewAllRecords\n\t\tpo.allowRead = true\n\tif po.modifyAllRecords\n\t\tpo.allowRead = true\n\t\tpo.allowEdit = true\n\t\tpo.allowDelete = true\n\t\tpo.viewAllRecords = true\n\tif po.viewCompanyRecords\n\t\tpo.allowRead = true\n\tif po.modifyCompanyRecords\n\t\tpo.allowRead = true\n\t\tpo.allowEdit = true\n\t\tpo.allowDelete = true\n\t\tpo.viewCompanyRecords = true\n\t\t\n\t# 如果附件相关权限配置为空,则兼容之前没有附件权限配置时的规则\n\tif po.allowRead\n\t\ttypeof po.allowReadFiles != \"boolean\" && po.allowReadFiles = true\n\t\ttypeof po.viewAllFiles != \"boolean\" && po.viewAllFiles = true\n\tif po.allowEdit\n\t\ttypeof po.allowCreateFiles != \"boolean\" && po.allowCreateFiles = true\n\t\ttypeof po.allowEditFiles != \"boolean\" && po.allowEditFiles = true\n\t\ttypeof po.allowDeleteFiles != \"boolean\" && po.allowDeleteFiles = true\n\tif po.modifyAllRecords\n\t\ttypeof po.modifyAllFiles != \"boolean\" && po.modifyAllFiles = true\n\n\tif po.allowCreateFiles\n\t\tpo.allowReadFiles = true\n\tif po.allowEditFiles\n\t\tpo.allowReadFiles = true\n\tif po.allowDeleteFiles\n\t\tpo.allowEditFiles = true\n\t\tpo.allowReadFiles = true\n\tif po.viewAllFiles\n\t\tpo.allowReadFiles = true\n\tif po.modifyAllFiles\n\t\tpo.allowReadFiles = true\n\t\tpo.allowEditFiles = true\n\t\tpo.allowDeleteFiles = true\n\t\tpo.viewAllFiles = true\n\n\treturn po\n\nCreator.getTemplateSpaceId = ()->\n\treturn Meteor.settings.public?.templateSpaceId\n\nCreator.getCloudAdminSpaceId = ()->\n\treturn Meteor.settings.public?.cloudAdminSpaceId\n\nCreator.isTemplateSpace = (spaceId)->\n\tif spaceId && Meteor.settings.public?.templateSpaceId == spaceId\n\t\treturn true\n\treturn false\n\nCreator.isCloudAdminSpace = (spaceId)->\n\tif spaceId && Meteor.settings.public?.cloudAdminSpaceId == spaceId\n\t\treturn true\n\treturn false\n\nif Meteor.isServer\n\tCreator.steedosStorageDir = process.env.STEEDOS_STORAGE_DIR\n\t","var Fiber;\n\nCreator.deps = {\n app: new Tracker.Dependency,\n object: new Tracker.Dependency\n};\n\nCreator._TEMPLATE = {\n Apps: {},\n Objects: {}\n};\n\nMeteor.startup(function() {\n SimpleSchema.extendOptions({\n filtersFunction: Match.Optional(Match.OneOf(Function, String))\n });\n SimpleSchema.extendOptions({\n optionsFunction: Match.Optional(Match.OneOf(Function, String))\n });\n return SimpleSchema.extendOptions({\n createFunction: Match.Optional(Match.OneOf(Function, String))\n });\n});\n\nif (Meteor.isServer) {\n Fiber = require('fibers');\n Creator.fiberLoadObjects = function(obj, object_name) {\n return Fiber(function() {\n return Creator.loadObjects(obj, object_name);\n }).run();\n };\n}\n\nCreator.loadObjects = function(obj, object_name) {\n if (!object_name) {\n object_name = obj.name;\n }\n if (!obj.list_views) {\n obj.list_views = {};\n }\n if (obj.space) {\n object_name = Creator.getCollectionName(obj);\n }\n if (object_name === 'cfs_files_filerecord') {\n object_name = 'cfs.files.filerecord';\n obj = _.clone(obj);\n obj.name = object_name;\n Creator.Objects[object_name] = obj;\n }\n Creator.convertObject(obj);\n new Creator.Object(obj);\n Creator.initTriggers(object_name);\n Creator.initListViews(object_name);\n return obj;\n};\n\nCreator.getObjectName = function(object) {\n if (object.space) {\n return \"c_\" + object.space + \"_\" + object.name;\n }\n return object.name;\n};\n\nCreator.getObject = function(object_name, space_id) {\n var ref, ref1;\n if (_.isArray(object_name)) {\n return;\n }\n if (Meteor.isClient) {\n if ((ref = Creator.deps) != null) {\n if ((ref1 = ref.object) != null) {\n ref1.depend();\n }\n }\n }\n if (!object_name && Meteor.isClient) {\n object_name = Session.get(\"object_name\");\n }\n if (object_name) {\n return Creator.objectsByName[object_name];\n }\n};\n\nCreator.getObjectById = function(object_id) {\n return _.findWhere(Creator.objectsByName, {\n _id: object_id\n });\n};\n\nCreator.removeObject = function(object_name) {\n console.log(\"removeObject\", object_name);\n delete Creator.Objects[object_name];\n return delete Creator.objectsByName[object_name];\n};\n\nCreator.getCollection = function(object_name, spaceId) {\n var ref;\n if (!object_name) {\n object_name = Session.get(\"object_name\");\n }\n if (object_name) {\n if (Meteor.isClient) {\n return db[object_name];\n } else {\n return Creator.Collections[((ref = Creator.getObject(object_name, spaceId)) != null ? ref._collection_name : void 0) || object_name];\n }\n }\n};\n\nCreator.removeCollection = function(object_name) {\n return delete Creator.Collections[object_name];\n};\n\nCreator.isSpaceAdmin = function(spaceId, userId) {\n var ref, ref1, space;\n if (Meteor.isClient) {\n if (!spaceId) {\n spaceId = Session.get(\"spaceId\");\n }\n if (!userId) {\n userId = Meteor.userId();\n }\n }\n space = (ref = Creator.getObject(\"spaces\")) != null ? (ref1 = ref.db) != null ? ref1.findOne(spaceId, {\n fields: {\n admins: 1\n }\n }) : void 0 : void 0;\n if (space != null ? space.admins : void 0) {\n return space.admins.indexOf(userId) >= 0;\n }\n};\n\nCreator.evaluateFormula = function(formular, context, options) {\n if (!_.isString(formular)) {\n return formular;\n }\n if (Creator.Formular.checkFormula(formular)) {\n return Creator.Formular.run(formular, context, options);\n }\n return formular;\n};\n\nCreator.evaluateFilters = function(filters, context) {\n var selector;\n selector = {};\n _.each(filters, function(filter) {\n var action, name, value;\n if ((filter != null ? filter.length : void 0) === 3) {\n name = filter[0];\n action = filter[1];\n value = Creator.evaluateFormula(filter[2], context);\n selector[name] = {};\n return selector[name][action] = value;\n }\n });\n return selector;\n};\n\nCreator.isCommonSpace = function(spaceId) {\n return spaceId === 'common';\n};\n\n\n/*\n\tdocs:待排序的文档数组\n\tids:_id集合\n\tid_key: 默认为_id\n\treturn 按照ids的顺序返回新的文档集合\n */\n\nCreator.getOrderlySetByIds = function(docs, ids, id_key, hit_first) {\n var values;\n if (!id_key) {\n id_key = \"_id\";\n }\n if (hit_first) {\n values = docs.getProperty(id_key);\n return _.sortBy(docs, function(doc) {\n var _index;\n _index = ids.indexOf(doc[id_key]);\n if (_index > -1) {\n return _index;\n } else {\n return ids.length + _.indexOf(values, doc[id_key]);\n }\n });\n } else {\n return _.sortBy(docs, function(doc) {\n return ids.indexOf(doc[id_key]);\n });\n }\n};\n\n\n/*\n\t按用户所属本地化语言进行排序,支持中文、数值、日期等字段排序\n\t对于Object类型,如果提供作用域中key属性,则取值为value[key]进行排序比较,反之整个Object.toString()后排序比较\n */\n\nCreator.sortingMethod = function(value1, value2) {\n var isValue1Empty, isValue2Empty, locale;\n if (this.key) {\n value1 = value1[this.key];\n value2 = value2[this.key];\n }\n if (value1 instanceof Date) {\n value1 = value1.getTime();\n }\n if (value2 instanceof Date) {\n value2 = value2.getTime();\n }\n if (typeof value1 === \"number\" && typeof value2 === \"number\") {\n return value1 - value2;\n }\n isValue1Empty = value1 === null || value1 === void 0;\n isValue2Empty = value2 === null || value2 === void 0;\n if (isValue1Empty && !isValue2Empty) {\n return -1;\n }\n if (isValue1Empty && isValue2Empty) {\n return 0;\n }\n if (!isValue1Empty && isValue2Empty) {\n return 1;\n }\n locale = Steedos.locale();\n return value1.toString().localeCompare(value2.toString(), locale);\n};\n\nCreator.getObjectRelateds = function(object_name) {\n var _object, permissions, relatedList, relatedListMap, related_objects;\n if (Meteor.isClient) {\n if (!object_name) {\n object_name = Session.get(\"object_name\");\n }\n }\n related_objects = [];\n _object = Creator.Objects[object_name];\n if (!_object) {\n return related_objects;\n }\n relatedList = _object.relatedList;\n if (Meteor.isClient && !_.isEmpty(relatedList)) {\n relatedListMap = {};\n _.each(relatedList, function(objName) {\n if (_.isObject(objName)) {\n return relatedListMap[objName.objectName] = {};\n } else {\n return relatedListMap[objName] = {};\n }\n });\n _.each(Creator.Objects, function(related_object, related_object_name) {\n return _.each(related_object.fields, function(related_field, related_field_name) {\n if ((related_field.type === \"master_detail\" || related_field.type === \"lookup\") && related_field.reference_to && related_field.reference_to === object_name && relatedListMap[related_object_name]) {\n if (_.isEmpty(relatedListMap[related_object_name] || related_field.type === \"master_detail\")) {\n return relatedListMap[related_object_name] = {\n object_name: related_object_name,\n foreign_key: related_field_name,\n write_requires_master_read: related_field.write_requires_master_read\n };\n }\n }\n });\n });\n if (relatedListMap['cms_files']) {\n relatedListMap['cms_files'] = {\n object_name: \"cms_files\",\n foreign_key: \"parent\"\n };\n }\n if (relatedListMap['instances']) {\n relatedListMap['instances'] = {\n object_name: \"instances\",\n foreign_key: \"record_ids\"\n };\n }\n _.each(['tasks', 'notes', 'events', 'approvals'], function(enableObjName) {\n if (relatedListMap[enableObjName]) {\n return relatedListMap[enableObjName] = {\n object_name: enableObjName,\n foreign_key: \"related_to\"\n };\n }\n });\n if (relatedListMap['audit_records']) {\n permissions = Creator.getPermissions(object_name);\n if (_object.enable_audit && (permissions != null ? permissions.modifyAllRecords : void 0)) {\n relatedListMap['audit_records'] = {\n object_name: \"audit_records\",\n foreign_key: \"related_to\"\n };\n }\n }\n related_objects = _.values(relatedListMap);\n return related_objects;\n }\n if (_object.enable_files) {\n related_objects.push({\n object_name: \"cms_files\",\n foreign_key: \"parent\"\n });\n }\n _.each(Creator.Objects, function(related_object, related_object_name) {\n var sfsFilesObject;\n if (related_object_name === \"cfs.files.filerecord\") {\n sfsFilesObject = Creator.getObject(\"cfs.files.filerecord\");\n sfsFilesObject && (related_object = sfsFilesObject);\n }\n return _.each(related_object.fields, function(related_field, related_field_name) {\n if ((related_field.type === \"master_detail\" || (related_field.type === \"lookup\" && related_field.relatedList)) && related_field.reference_to && related_field.reference_to === object_name) {\n if (related_object_name === \"object_fields\") {\n return related_objects.splice(0, 0, {\n object_name: related_object_name,\n foreign_key: related_field_name\n });\n } else {\n return related_objects.push({\n object_name: related_object_name,\n foreign_key: related_field_name,\n write_requires_master_read: related_field.write_requires_master_read\n });\n }\n }\n });\n });\n if (_object.enable_tasks) {\n related_objects.push({\n object_name: \"tasks\",\n foreign_key: \"related_to\"\n });\n }\n if (_object.enable_notes) {\n related_objects.push({\n object_name: \"notes\",\n foreign_key: \"related_to\"\n });\n }\n if (_object.enable_events) {\n related_objects.push({\n object_name: \"events\",\n foreign_key: \"related_to\"\n });\n }\n if (_object.enable_instances) {\n related_objects.push({\n object_name: \"instances\",\n foreign_key: \"record_ids\"\n });\n }\n if (_object.enable_approvals) {\n related_objects.push({\n object_name: \"approvals\",\n foreign_key: \"related_to\"\n });\n }\n if (_object.enable_process) {\n related_objects.push({\n object_name: \"process_instance_history\",\n foreign_key: \"target_object\"\n });\n }\n if (Meteor.isClient) {\n permissions = Creator.getPermissions(object_name);\n if (_object.enable_audit && (permissions != null ? permissions.modifyAllRecords : void 0)) {\n related_objects.push({\n object_name: \"audit_records\",\n foreign_key: \"related_to\"\n });\n }\n }\n return related_objects;\n};\n\nCreator.getUserContext = function(userId, spaceId, isUnSafeMode) {\n var USER_CONTEXT, ref, space_user_org, su, suFields;\n if (Meteor.isClient) {\n return Creator.USER_CONTEXT;\n } else {\n if (!(userId && spaceId)) {\n throw new Meteor.Error(500, \"the params userId and spaceId is required for the function Creator.getUserContext\");\n return null;\n }\n suFields = {\n name: 1,\n mobile: 1,\n position: 1,\n email: 1,\n company: 1,\n organization: 1,\n space: 1,\n company_id: 1,\n company_ids: 1\n };\n su = Creator.Collections[\"space_users\"].findOne({\n space: spaceId,\n user: userId\n }, {\n fields: suFields\n });\n if (!su) {\n spaceId = null;\n }\n if (!spaceId) {\n if (isUnSafeMode) {\n su = Creator.Collections[\"space_users\"].findOne({\n user: userId\n }, {\n fields: suFields\n });\n if (!su) {\n return null;\n }\n spaceId = su.space;\n } else {\n return null;\n }\n }\n USER_CONTEXT = {};\n USER_CONTEXT.userId = userId;\n USER_CONTEXT.spaceId = spaceId;\n USER_CONTEXT.user = {\n _id: userId,\n name: su.name,\n mobile: su.mobile,\n position: su.position,\n email: su.email,\n company: su.company,\n company_id: su.company_id,\n company_ids: su.company_ids\n };\n space_user_org = (ref = Creator.getCollection(\"organizations\")) != null ? ref.findOne(su.organization) : void 0;\n if (space_user_org) {\n USER_CONTEXT.user.organization = {\n _id: space_user_org._id,\n name: space_user_org.name,\n fullname: space_user_org.fullname\n };\n }\n return USER_CONTEXT;\n }\n};\n\nCreator.getRelativeUrl = function(url) {\n if (_.isFunction(Steedos.isCordova) && Steedos.isCordova() && ((url != null ? url.startsWith(\"/assets\") : void 0) || (url != null ? url.startsWith(\"assets\") : void 0) || (url != null ? url.startsWith(\"/packages\") : void 0))) {\n if (!/^\\//.test(url)) {\n url = \"/\" + url;\n }\n return url;\n }\n if (url) {\n if (!/^\\//.test(url)) {\n url = \"/\" + url;\n }\n return __meteor_runtime_config__.ROOT_URL_PATH_PREFIX + url;\n } else {\n return __meteor_runtime_config__.ROOT_URL_PATH_PREFIX;\n }\n};\n\nCreator.getUserCompanyId = function(userId, spaceId) {\n var su;\n userId = userId || Meteor.userId();\n if (Meteor.isClient) {\n spaceId = spaceId || Session.get('spaceId');\n } else {\n if (!spaceId) {\n throw new Meteor.Error(400, 'miss spaceId');\n }\n }\n su = Creator.getCollection('space_users').findOne({\n space: spaceId,\n user: userId\n }, {\n fields: {\n company_id: 1\n }\n });\n return su.company_id;\n};\n\nCreator.getUserCompanyIds = function(userId, spaceId) {\n var su;\n userId = userId || Meteor.userId();\n if (Meteor.isClient) {\n spaceId = spaceId || Session.get('spaceId');\n } else {\n if (!spaceId) {\n throw new Meteor.Error(400, 'miss spaceId');\n }\n }\n su = Creator.getCollection('space_users').findOne({\n space: spaceId,\n user: userId\n }, {\n fields: {\n company_ids: 1\n }\n });\n return su != null ? su.company_ids : void 0;\n};\n\nCreator.processPermissions = function(po) {\n if (po.allowCreate) {\n po.allowRead = true;\n }\n if (po.allowEdit) {\n po.allowRead = true;\n }\n if (po.allowDelete) {\n po.allowEdit = true;\n po.allowRead = true;\n }\n if (po.viewAllRecords) {\n po.allowRead = true;\n }\n if (po.modifyAllRecords) {\n po.allowRead = true;\n po.allowEdit = true;\n po.allowDelete = true;\n po.viewAllRecords = true;\n }\n if (po.viewCompanyRecords) {\n po.allowRead = true;\n }\n if (po.modifyCompanyRecords) {\n po.allowRead = true;\n po.allowEdit = true;\n po.allowDelete = true;\n po.viewCompanyRecords = true;\n }\n if (po.allowRead) {\n typeof po.allowReadFiles !== \"boolean\" && (po.allowReadFiles = true);\n typeof po.viewAllFiles !== \"boolean\" && (po.viewAllFiles = true);\n }\n if (po.allowEdit) {\n typeof po.allowCreateFiles !== \"boolean\" && (po.allowCreateFiles = true);\n typeof po.allowEditFiles !== \"boolean\" && (po.allowEditFiles = true);\n typeof po.allowDeleteFiles !== \"boolean\" && (po.allowDeleteFiles = true);\n }\n if (po.modifyAllRecords) {\n typeof po.modifyAllFiles !== \"boolean\" && (po.modifyAllFiles = true);\n }\n if (po.allowCreateFiles) {\n po.allowReadFiles = true;\n }\n if (po.allowEditFiles) {\n po.allowReadFiles = true;\n }\n if (po.allowDeleteFiles) {\n po.allowEditFiles = true;\n po.allowReadFiles = true;\n }\n if (po.viewAllFiles) {\n po.allowReadFiles = true;\n }\n if (po.modifyAllFiles) {\n po.allowReadFiles = true;\n po.allowEditFiles = true;\n po.allowDeleteFiles = true;\n po.viewAllFiles = true;\n }\n return po;\n};\n\nCreator.getTemplateSpaceId = function() {\n var ref;\n return (ref = Meteor.settings[\"public\"]) != null ? ref.templateSpaceId : void 0;\n};\n\nCreator.getCloudAdminSpaceId = function() {\n var ref;\n return (ref = Meteor.settings[\"public\"]) != null ? ref.cloudAdminSpaceId : void 0;\n};\n\nCreator.isTemplateSpace = function(spaceId) {\n var ref;\n if (spaceId && ((ref = Meteor.settings[\"public\"]) != null ? ref.templateSpaceId : void 0) === spaceId) {\n return true;\n }\n return false;\n};\n\nCreator.isCloudAdminSpace = function(spaceId) {\n var ref;\n if (spaceId && ((ref = Meteor.settings[\"public\"]) != null ? ref.cloudAdminSpaceId : void 0) === spaceId) {\n return true;\n }\n return false;\n};\n\nif (Meteor.isServer) {\n Creator.steedosStorageDir = process.env.STEEDOS_STORAGE_DIR;\n}\n","Meteor.methods\n\t# 用户获取lookup 、master_detail类型字段的选项值\n\t\"creator.object_options\": (options)->\n\t\tif options?.params?.reference_to\n\n\t\t\tobject = Creator.getObject(options.params.reference_to, options.params.space)\n\n\t\t\tname_field_key = object.NAME_FIELD_KEY\n\n\t\t\tquery = {}\n\t\t\tif options.params.space\n\t\t\t\tquery.space = options.params.space\n\n\t\t\t\tsort = options?.sort\n\n\t\t\t\tselected = options?.selected || []\n\n\t\t\t\toptions_limit = options?.options_limit || 10\n\n\t\t\t\tif options.searchText\n\t\t\t\t\tsearchTextQuery = {}\n\t\t\t\t\tsearchTextQuery[name_field_key] = {$regex: options.searchText}\n\n\t\t\t\tif options?.values?.length\n\t\t\t\t\tif options.searchText\n\t\t\t\t\t\tquery.$or = [{_id: {$in: options.values}}, searchTextQuery]\n\t\t\t\t\telse\n\t\t\t\t\t\tquery.$or = [{_id: {$in: options.values}}]\n\t\t\t\telse\n\t\t\t\t\tif options.searchText\n\t\t\t\t\t\t_.extend(query, searchTextQuery)\n\t\t\t\t\tquery._id = {$nin: selected}\n\n\t\t\t\tcollection = object.db\n\n\t\t\t\tif options.filterQuery\n\t\t\t\t\t_.extend query, options.filterQuery\n\n\t\t\t\tquery_options = {limit: options_limit}\n\n\t\t\t\tif sort && _.isObject(sort)\n\t\t\t\t\tquery_options.sort = sort\n\n\t\t\t\tif collection\n\t\t\t\t\ttry\n\t\t\t\t\t\trecords = collection.find(query, query_options).fetch()\n\t\t\t\t\t\tresults = []\n\t\t\t\t\t\t_.each records, (record)->\n\t\t\t\t\t\t\tresults.push\n\t\t\t\t\t\t\t\tlabel: record[name_field_key]\n\t\t\t\t\t\t\t\tvalue: record._id\n\t\t\t\t\t\treturn results\n\t\t\t\t\tcatch e\n\t\t\t\t\t\tthrow new Meteor.Error 500, e.message + \"-->\" + JSON.stringify(options)\n\t\treturn [] ","Meteor.methods({\n \"creator.object_options\": function(options) {\n var collection, e, name_field_key, object, options_limit, query, query_options, records, ref, ref1, results, searchTextQuery, selected, sort;\n if (options != null ? (ref = options.params) != null ? ref.reference_to : void 0 : void 0) {\n object = Creator.getObject(options.params.reference_to, options.params.space);\n name_field_key = object.NAME_FIELD_KEY;\n query = {};\n if (options.params.space) {\n query.space = options.params.space;\n sort = options != null ? options.sort : void 0;\n selected = (options != null ? options.selected : void 0) || [];\n options_limit = (options != null ? options.options_limit : void 0) || 10;\n if (options.searchText) {\n searchTextQuery = {};\n searchTextQuery[name_field_key] = {\n $regex: options.searchText\n };\n }\n if (options != null ? (ref1 = options.values) != null ? ref1.length : void 0 : void 0) {\n if (options.searchText) {\n query.$or = [\n {\n _id: {\n $in: options.values\n }\n }, searchTextQuery\n ];\n } else {\n query.$or = [\n {\n _id: {\n $in: options.values\n }\n }\n ];\n }\n } else {\n if (options.searchText) {\n _.extend(query, searchTextQuery);\n }\n query._id = {\n $nin: selected\n };\n }\n collection = object.db;\n if (options.filterQuery) {\n _.extend(query, options.filterQuery);\n }\n query_options = {\n limit: options_limit\n };\n if (sort && _.isObject(sort)) {\n query_options.sort = sort;\n }\n if (collection) {\n try {\n records = collection.find(query, query_options).fetch();\n results = [];\n _.each(records, function(record) {\n return results.push({\n label: record[name_field_key],\n value: record._id\n });\n });\n return results;\n } catch (error) {\n e = error;\n throw new Meteor.Error(500, e.message + \"-->\" + JSON.stringify(options));\n }\n }\n }\n }\n return [];\n }\n});\n","Creator.getInitWidthPercent = (object_name, columns) ->\n\t_schema = Creator.getSchema(object_name)?._schema\n\tcolumn_num = 0\n\tif _schema\n\t\t_.each columns, (field_name) ->\n\t\t\tfield = _.pick(_schema, field_name)\n\t\t\tis_wide = field[field_name]?.autoform?.is_wide\n\t\t\tif is_wide\n\t\t\t\tcolumn_num += 2\n\t\t\telse\n\t\t\t\tcolumn_num += 1\n\n\t\tinit_width_percent = 100 / column_num\n\t\treturn init_width_percent\n\nCreator.getFieldIsWide = (object_name, field_name) ->\n\t_schema = Creator.getSchema(object_name)._schema\n\tif _schema\n\t\tfield = _.pick(_schema, field_name)\n\t\tis_wide = field[field_name]?.autoform?.is_wide\n\t\treturn is_wide\n\nCreator.getTabularOrder = (object_name, list_view_id, columns) ->\n\tsetting = Creator.Collections?.settings?.findOne({object_name: object_name, record_id: \"object_listviews\"})\n\tobj = Creator.getObject(object_name)\n\tcolumns = _.map columns, (column)->\n\t\tfield = obj.fields[column]\n\t\tif field?.type and !field.hidden\n\t\t\treturn column\n\t\telse\n\t\t\treturn undefined\n\tcolumns = _.compact columns\n\tif setting and setting.settings\n\t\tsort = setting.settings[list_view_id]?.sort || []\n\t\tsort = _.map sort, (order)->\n\t\t\tkey = order[0]\n\t\t\tindex = _.indexOf(columns, key)\n\t\t\torder[0] = index + 1\n\t\t\treturn order\n\t\treturn sort\n\treturn []\n\n\nCreator.initListViews = (object_name)->\n\tobject = Creator.getObject(object_name)\n\tcolumns = Creator.getObjectDefaultColumns(object_name) || [\"name\"]\n\textra_columns = [\"owner\"]\n\tdefault_extra_columns = Creator.getObjectDefaultExtraColumns(object_name) || [\"owner\"]\n\tif default_extra_columns\n\t\textra_columns = _.union extra_columns, default_extra_columns\n\n\torder = Creator.getObjectDefaultSort(object_name) || []\n\tif Meteor.isClient\n\t\tCreator.TabularSelectedIds?[object_name] = []\n\nCreator.convertListView = (default_view, list_view, list_view_name)->\n\tdefault_columns = default_view?.columns\n\tdefault_mobile_columns = default_view?.mobile_columns\n\tunless list_view\n\t\treturn\n\toitem = _.clone(list_view)\n\tif !_.has(oitem, \"name\")\n\t\toitem.name = list_view_name\n\tif !oitem.columns\n\t\tif default_columns\n\t\t\toitem.columns = default_columns\n\tif !oitem.columns\n\t\toitem.columns = [\"name\"]\n\tif !oitem.mobile_columns\n\t\tif default_mobile_columns\n\t\t\toitem.mobile_columns = default_mobile_columns\n\n\tif Meteor.isClient\n\t\tif Creator.isCloudAdminSpace(Session.get(\"spaceId\")) && !_.include(oitem.columns, 'space')\n\t\t\toitem.columns.push('space')\n\n\n\tif !oitem.filter_scope\n\t\t# listview视图的filter_scope默认值改为space #131\n\t\toitem.filter_scope = \"space\"\n\n\tif !_.has(oitem, \"_id\")\n\t\toitem._id = list_view_name\n\telse\n\t\toitem.label = oitem.label || list_view.name\n\n\tif _.isString(oitem.options)\n\t\toitem.options = JSON.parse(oitem.options)\n\n\t_.forEach oitem.filters, (filter, _index)->\n\t\tif !_.isArray(filter) && _.isObject(filter)\n\t\t\tif Meteor.isServer\n\t\t\t\tif _.isFunction(filter?.value)\n\t\t\t\t\tfilter._value = filter.value.toString()\n\t\t\telse\n\t\t\t\tif _.isString(filter?._value)\n\t\t\t\t\tfilter.value = Creator.eval(\"(#{filter._value})\")\n\treturn oitem\n\n\nif Meteor.isClient\n\tCreator.getRelatedList = (object_name)->\n\t\tunless object_name\n\t\t\treturn\n\t\trelatedListObjects = {}\n\t\trelatedListNames = []\n\t\tobjectLayoutRelatedListObjects = [];\n\t\t_object = Creator.getObject(object_name)\n\t\tif _object\n\t\t\tlayoutRelatedList = _object.related_lists;\n\t\t\t# layoutRelatedList 是数组就表示配置过页面布局,就启用页面布局的相关子表。\n\t\t\tif _.isArray layoutRelatedList\n\t\t\t\t_.each layoutRelatedList, (item)->\n\t\t\t\t\treObjectName = item.related_field_fullname.split('.')[0]\n\t\t\t\t\treFieldName = item.related_field_fullname.split('.')[1]\n\t\t\t\t\twrite_requires_master_read = Creator.getObject(reObjectName)?.fields[reFieldName]?.write_requires_master_read\n\t\t\t\t\trelated =\n\t\t\t\t\t\tobject_name: reObjectName\n\t\t\t\t\t\tcolumns: item.field_names\n\t\t\t\t\t\tmobile_columns: item.field_names\n\t\t\t\t\t\tis_file: reObjectName == \"cms_files\"\n\t\t\t\t\t\tfiltersFunction: item.filters\n\t\t\t\t\t\tsort: item.sort\n\t\t\t\t\t\trelated_field_name: reFieldName\n\t\t\t\t\t\tcustomRelatedListObject: true\n\t\t\t\t\t\twrite_requires_master_read: write_requires_master_read\n\t\t\t\t\t\tlabel: item.label\n\t\t\t\t\t\tactions: item.buttons\n\t\t\t\t\t\tvisible_on: item.visible_on\n\t\t\t\t\t\tpage_size: item.page_size\n\t\t\t\t\tobjectLayoutRelatedListObjects.push(related)\n\t\t\t\treturn objectLayoutRelatedListObjects;\n\t\t\trelatedList = _object.relatedList\n\t\t\tif !_.isEmpty relatedList\n\t\t\t\t_.each relatedList, (objOrName)->\n\t\t\t\t\tif _.isObject objOrName\n\t\t\t\t\t\trelated =\n\t\t\t\t\t\t\tobject_name: objOrName.objectName\n\t\t\t\t\t\t\tcolumns: objOrName.columns\n\t\t\t\t\t\t\tmobile_columns: objOrName.mobile_columns\n\t\t\t\t\t\t\tis_file: objOrName.objectName == \"cms_files\"\n\t\t\t\t\t\t\tfiltersFunction: objOrName.filters\n\t\t\t\t\t\t\tsort: objOrName.sort\n\t\t\t\t\t\t\trelated_field_name: ''\n\t\t\t\t\t\t\tcustomRelatedListObject: true\n\t\t\t\t\t\t\tlabel: objOrName.label\n\t\t\t\t\t\t\tactions: objOrName.actions\n\t\t\t\t\t\t\tpage_size: objOrName.page_size\n\t\t\t\t\t\trelatedListObjects[objOrName.objectName] = related\n\t\t\t\t\t\trelatedListNames.push objOrName.objectName\n\t\t\t\t\telse if _.isString objOrName\n\t\t\t\t\t\trelatedListNames.push objOrName\n\n\t\tmapList = {}\n\t\trelated_objects = Creator.getRelatedObjects(object_name)\n\t\t_.each related_objects, (related_object_item) ->\n\t\t\tif !related_object_item?.object_name\n\t\t\t\treturn\n\t\t\trelated_object_name = related_object_item.object_name\n\t\t\trelated_field_name = related_object_item.foreign_key\n\t\t\twrite_requires_master_read = related_object_item.write_requires_master_read\n\t\t\trelated_object = Creator.getObject(related_object_name)\n\t\t\tunless related_object\n\t\t\t\treturn\n\t\t\tcolumns = Creator.getObjectFirstListViewColumns(related_object_name) || [\"name\"]\n\t\t\tcolumns = _.without(columns, related_field_name)\n\t\t\tmobile_columns = Creator.getObjectFirstListViewColumns(related_object_name, true) || [\"name\"]\n\t\t\tmobile_columns = _.without(mobile_columns, related_field_name)\n\n\t\t\torder = Creator.getObjectDefaultSort(related_object_name)\n\t\t\ttabular_order = Creator.transformSortToTabular(order, columns)\n\n\t\t\tif /\\w+\\.\\$\\.\\w+/g.test(related_field_name)\n\t\t\t\t# object类型带子属性的related_field_name要去掉中间的美元符号,否则显示不出字段值\n\t\t\t\trelated_field_name = related_field_name.replace(/\\$\\./,\"\")\n\t\t\trelated =\n\t\t\t\tobject_name: related_object_name\n\t\t\t\tcolumns: columns\n\t\t\t\tmobile_columns: mobile_columns\n\t\t\t\trelated_field_name: related_field_name\n\t\t\t\tis_file: related_object_name == \"cms_files\"\n\t\t\t\twrite_requires_master_read: write_requires_master_read\n\n\t\t\trelatedObject = relatedListObjects[related_object_name]\n\t\t\tif relatedObject\n\t\t\t\tif relatedObject.columns\n\t\t\t\t\trelated.columns = relatedObject.columns\n\t\t\t\tif relatedObject.mobile_columns\n\t\t\t\t\trelated.mobile_columns = relatedObject.mobile_columns\n\t\t\t\tif relatedObject.sort\n\t\t\t\t\trelated.sort = relatedObject.sort\n\t\t\t\tif relatedObject.filtersFunction\n\t\t\t\t\trelated.filtersFunction = relatedObject.filtersFunction\n\t\t\t\tif relatedObject.customRelatedListObject\n\t\t\t\t\trelated.customRelatedListObject = relatedObject.customRelatedListObject\n\t\t\t\tif relatedObject.label\n\t\t\t\t\trelated.label = relatedObject.label\n\t\t\t\tif relatedObject.page_size\n\t\t\t\t\trelated.page_size = relatedObject.page_size\n\t\t\t\tdelete relatedListObjects[related_object_name]\n\n\t\t\tmapList[related.object_name] = related\n\n\n\t\tspaceId = Session.get(\"spaceId\")\n\t\tuserId = Meteor.userId()\n\t\trelated_object_names = _.pluck(_.values(relatedListObjects), \"object_name\")\n\t\tpermissions = Creator.getPermissions(object_name, spaceId, userId)\n\t\tunrelated_objects = permissions.unrelated_objects\n\t\trelated_object_names = _.difference related_object_names, unrelated_objects\n\t\t_.each relatedListObjects, (v, related_object_name) ->\n\t\t\tisActive = related_object_names.indexOf(related_object_name) > -1\n\t\t\tallowRead = Creator.getPermissions(related_object_name, spaceId, userId)?.allowRead\n\t\t\tif isActive && allowRead\n\t\t\t\tmapList[related_object_name] = v\n\n\t\tlist = []\n\t\tif _.isEmpty relatedListNames\n\t\t\tlist = _.values mapList\n\t\telse\n\t\t\t_.each relatedListNames, (objectName) ->\n\t\t\t\tif mapList[objectName]\n\t\t\t\t\tlist.push mapList[objectName]\n\n\t\tif _.has(_object, 'allow_relatedList')\n\t\t\tlist = _.filter list, (item)->\n\t\t\t\treturn _.include(_object.allow_relatedList, item.object_name)\n\n\t\treturn list\n\nCreator.getObjectFirstListView = (object_name)->\n\treturn _.first(Creator.getListViews(object_name))\n\n### \n\t取出list_view_id对应的视图,如果不存在或者没有权限,就返回第一个视图\n\texac为true时,需要强制按list_view_id精确查找,不默认返回第一个视图\n###\nCreator.getListView = (object_name, list_view_id, exac)->\n\tif Meteor.isClient\n\t\tif !object_name\n\t\t\tobject_name = Session.get(\"object_name\")\n\t\tif !list_view_id\n\t\t\tlist_view_id = Session.get(\"list_view_id\")\n\tobject = Creator.getObject(object_name)\n\tif !object\n\t\treturn\n\tlistViews = Creator.getListViews(object_name)\n\tunless listViews?.length\n\t\treturn\n\tlist_view = _.find(listViews, (item)-> return item._id == list_view_id || item.name == list_view_id)\n\tunless list_view\n\t\t# 如果不需要强制按list_view_id精确查找,则默认返回第一个视图,反之返回空\n\t\tif exac\n\t\t\treturn\n\t\telse\n\t\t\tlist_view = listViews[0]\n\treturn list_view\n\n#获取list_view_id对应的视图是否是最近查看视图\nCreator.getListViewIsRecent = (object_name, list_view_id)->\n\tif Meteor.isClient\n\t\tif !object_name\n\t\t\tobject_name = Session.get(\"object_name\")\n\t\tif !list_view_id\n\t\t\tlist_view_id = Session.get(\"list_view_id\")\n\tif typeof(list_view_id) == \"string\"\n\t\tobject = Creator.getObject(object_name)\n\t\tif !object\n\t\t\treturn\n\t\tlistView = _.findWhere(object.list_views,{_id: list_view_id})\n\telse\n\t\tlistView = list_view_id\n\treturn listView?.name == \"recent\"\n\n\n###\n 从columns参数中过滤出用于手机端显示的columns\n\t规则:\n\t1.优先把columns中的name字段排在第一个\n\t2.最多只返回4个字段\n\t3.考虑宽字段占用整行规则条件下,最多只返回两行\n###\nCreator.pickObjectMobileColumns = (object_name, columns)->\n\tresult = []\n\tmaxRows = 2 \n\tmaxCount = maxRows * 2\n\tcount = 0\n\tobject = Creator.getObject(object_name)\n\tfields = object.fields\n\tunless object\n\t\treturn columns\n\tnameKey = object.NAME_FIELD_KEY\n\tisNameColumn = (item)->\n\t\tif _.isObject(item)\n\t\t\treturn item.field == nameKey\n\t\telse\n\t\t\treturn item == nameKey\n\tgetField = (item)->\n\t\tif _.isObject(item)\n\t\t\treturn fields[item.field]\n\t\telse\n\t\t\treturn fields[item]\n\tif nameKey\n\t\tnameColumn = columns.find (item)->\n\t\t\treturn isNameColumn(item)\n\tif nameColumn\n\t\tfield = getField(nameColumn)\n\t\titemCount = if field.is_wide then 2 else 1\n\t\tcount += itemCount\n\t\tresult.push nameColumn\n\tcolumns.forEach (item)->\n\t\tfield = getField(item)\n\t\tunless field\n\t\t\treturn\n\t\titemCount = if field.is_wide then 2 else 1\n\t\tif count < maxCount and result.length < maxCount and !isNameColumn(item)\n\t\t\tcount += itemCount\n\t\t\tif count <= maxCount\n\t\t\t\tresult.push item\n\t\n\treturn result\n\n###\n 获取默认视图\n###\nCreator.getObjectDefaultView = (object_name)->\n\tobject = Creator.getObject(object_name)\n\tif !object\n\t\tobject = Creator.Objects[object_name]\n\tif object?.list_views?.default\n\t\t#TODO 此代码只是暂时兼容以前code中定义的default视图,待code中的default清理完成后,需要删除此代码\n\t\tdefaultView = object.list_views.default\n\telse\n\t\t_.each object?.list_views, (list_view, key)->\n\t\t\tif list_view.name == \"all\" || key == \"all\"\n\t\t\t\tdefaultView = list_view\n\treturn defaultView;\n\n###\n 获取对象的列表默认显示字段\n###\nCreator.getObjectDefaultColumns = (object_name, use_mobile_columns)->\n\tdefaultView = Creator.getObjectDefaultView(object_name)\n\tcolumns = defaultView?.columns\n\tif use_mobile_columns\n\t\tif defaultView?.mobile_columns\n\t\t\tcolumns = defaultView.mobile_columns\n\t\telse if columns\n\t\t\tcolumns = Creator.pickObjectMobileColumns(object_name, columns)\n\treturn columns\n\n###\n 获取对象的列表第一个视图显示的字段\n###\nCreator.getObjectFirstListViewColumns = (object_name, use_mobile_columns)->\n\tdefaultView = Creator.getObjectFirstListView(object_name)\n\tcolumns = defaultView?.columns\n\tif use_mobile_columns\n\t\tif defaultView?.mobile_columns\n\t\t\tcolumns = defaultView.mobile_columns\n\t\telse if columns\n\t\t\tcolumns = Creator.pickObjectMobileColumns(object_name, columns)\n\treturn columns\n\n###\n\t获取对象的列表默认额外加载的字段\n###\nCreator.getObjectDefaultExtraColumns = (object_name)->\n\tdefaultView = Creator.getObjectDefaultView(object_name)\n\treturn defaultView?.extra_columns\n\n###\n\t获取对象的默认排序\n###\nCreator.getObjectDefaultSort = (object_name)->\n\tdefaultView = Creator.getObjectDefaultView(object_name)\n\tif defaultView\n\t\tif defaultView.sort\n\t\t\treturn defaultView.sort\n\t\telse\n\t\t\treturn [[\"created\", \"desc\"]]\n\n\n###\n 判断是否All view\n###\nCreator.isAllView = (list_view)->\n\treturn list_view?.name == \"all\"\n\n###\n 判断是否最近查看 view\n###\nCreator.isRecentView = (list_view)->\n\treturn list_view?.name == \"recent\"\n\n###\n 将sort转换为Tabular控件所需要的格式\n###\nCreator.transformSortToTabular = (sort, tabularColumns)->\n\ttabular_sort = []\n\t_.each sort, (item)->\n\t\tif _.isArray(item)\n\t\t\t# 兼容旧的数据格式[[\"field_name\", \"order\"]]\n\t\t\tif item.length == 1\n\t\t\t\tcolumn_index = tabularColumns.indexOf(item[0])\n\t\t\t\tif column_index > -1\n\t\t\t\t\ttabular_sort.push [column_index, \"asc\"]\n\t\t\telse if item.length == 2\n\t\t\t\tcolumn_index = tabularColumns.indexOf(item[0])\n\t\t\t\tif column_index > -1\n\t\t\t\t\ttabular_sort.push [column_index, item[1]]\n\t\telse if _.isObject(item)\n\t\t\t#新数据格式:[{field_name: , order: }]\n\t\t\tfield_name = item.field_name\n\t\t\torder = item.order\n\t\t\tif field_name && order\n\t\t\t\tcolumn_index = tabularColumns.indexOf(field_name)\n\t\t\t\tif column_index > -1\n\t\t\t\t\ttabular_sort.push [column_index, order]\n\n\treturn tabular_sort\n\n###\n 将sort转换为DevExpress控件所需要的格式\n###\nCreator.transformSortToDX = (sort)->\n\tdx_sort = []\n\t_.each sort, (item)->\n\t\tif _.isArray(item)\n\t\t\t#兼容旧格式:[[\"field_name\", \"order\"]]\n\t\t\tdx_sort.push(item)\n\t\telse if _.isObject(item)\n\t\t\t#新数据格式:[{field_name: , order: }]\n\t\t\tfield_name = item.field_name\n\t\t\torder = item.order\n\t\t\tif field_name && order\n\t\t\t\tdx_sort.push [field_name, order]\n\n\treturn dx_sort\n","Creator.getInitWidthPercent = function(object_name, columns) {\n var _schema, column_num, init_width_percent, ref;\n _schema = (ref = Creator.getSchema(object_name)) != null ? ref._schema : void 0;\n column_num = 0;\n if (_schema) {\n _.each(columns, function(field_name) {\n var field, is_wide, ref1, ref2;\n field = _.pick(_schema, field_name);\n is_wide = (ref1 = field[field_name]) != null ? (ref2 = ref1.autoform) != null ? ref2.is_wide : void 0 : void 0;\n if (is_wide) {\n return column_num += 2;\n } else {\n return column_num += 1;\n }\n });\n init_width_percent = 100 / column_num;\n return init_width_percent;\n }\n};\n\nCreator.getFieldIsWide = function(object_name, field_name) {\n var _schema, field, is_wide, ref, ref1;\n _schema = Creator.getSchema(object_name)._schema;\n if (_schema) {\n field = _.pick(_schema, field_name);\n is_wide = (ref = field[field_name]) != null ? (ref1 = ref.autoform) != null ? ref1.is_wide : void 0 : void 0;\n return is_wide;\n }\n};\n\nCreator.getTabularOrder = function(object_name, list_view_id, columns) {\n var obj, ref, ref1, ref2, setting, sort;\n setting = (ref = Creator.Collections) != null ? (ref1 = ref.settings) != null ? ref1.findOne({\n object_name: object_name,\n record_id: \"object_listviews\"\n }) : void 0 : void 0;\n obj = Creator.getObject(object_name);\n columns = _.map(columns, function(column) {\n var field;\n field = obj.fields[column];\n if ((field != null ? field.type : void 0) && !field.hidden) {\n return column;\n } else {\n return void 0;\n }\n });\n columns = _.compact(columns);\n if (setting && setting.settings) {\n sort = ((ref2 = setting.settings[list_view_id]) != null ? ref2.sort : void 0) || [];\n sort = _.map(sort, function(order) {\n var index, key;\n key = order[0];\n index = _.indexOf(columns, key);\n order[0] = index + 1;\n return order;\n });\n return sort;\n }\n return [];\n};\n\nCreator.initListViews = function(object_name) {\n var columns, default_extra_columns, extra_columns, object, order, ref;\n object = Creator.getObject(object_name);\n columns = Creator.getObjectDefaultColumns(object_name) || [\"name\"];\n extra_columns = [\"owner\"];\n default_extra_columns = Creator.getObjectDefaultExtraColumns(object_name) || [\"owner\"];\n if (default_extra_columns) {\n extra_columns = _.union(extra_columns, default_extra_columns);\n }\n order = Creator.getObjectDefaultSort(object_name) || [];\n if (Meteor.isClient) {\n return (ref = Creator.TabularSelectedIds) != null ? ref[object_name] = [] : void 0;\n }\n};\n\nCreator.convertListView = function(default_view, list_view, list_view_name) {\n var default_columns, default_mobile_columns, oitem;\n default_columns = default_view != null ? default_view.columns : void 0;\n default_mobile_columns = default_view != null ? default_view.mobile_columns : void 0;\n if (!list_view) {\n return;\n }\n oitem = _.clone(list_view);\n if (!_.has(oitem, \"name\")) {\n oitem.name = list_view_name;\n }\n if (!oitem.columns) {\n if (default_columns) {\n oitem.columns = default_columns;\n }\n }\n if (!oitem.columns) {\n oitem.columns = [\"name\"];\n }\n if (!oitem.mobile_columns) {\n if (default_mobile_columns) {\n oitem.mobile_columns = default_mobile_columns;\n }\n }\n if (Meteor.isClient) {\n if (Creator.isCloudAdminSpace(Session.get(\"spaceId\")) && !_.include(oitem.columns, 'space')) {\n oitem.columns.push('space');\n }\n }\n if (!oitem.filter_scope) {\n oitem.filter_scope = \"space\";\n }\n if (!_.has(oitem, \"_id\")) {\n oitem._id = list_view_name;\n } else {\n oitem.label = oitem.label || list_view.name;\n }\n if (_.isString(oitem.options)) {\n oitem.options = JSON.parse(oitem.options);\n }\n _.forEach(oitem.filters, function(filter, _index) {\n if (!_.isArray(filter) && _.isObject(filter)) {\n if (Meteor.isServer) {\n if (_.isFunction(filter != null ? filter.value : void 0)) {\n return filter._value = filter.value.toString();\n }\n } else {\n if (_.isString(filter != null ? filter._value : void 0)) {\n return filter.value = Creator[\"eval\"](\"(\" + filter._value + \")\");\n }\n }\n }\n });\n return oitem;\n};\n\nif (Meteor.isClient) {\n Creator.getRelatedList = function(object_name) {\n var _object, layoutRelatedList, list, mapList, objectLayoutRelatedListObjects, permissions, relatedList, relatedListNames, relatedListObjects, related_object_names, related_objects, spaceId, unrelated_objects, userId;\n if (!object_name) {\n return;\n }\n relatedListObjects = {};\n relatedListNames = [];\n objectLayoutRelatedListObjects = [];\n _object = Creator.getObject(object_name);\n if (_object) {\n layoutRelatedList = _object.related_lists;\n if (_.isArray(layoutRelatedList)) {\n _.each(layoutRelatedList, function(item) {\n var reFieldName, reObjectName, ref, ref1, related, write_requires_master_read;\n reObjectName = item.related_field_fullname.split('.')[0];\n reFieldName = item.related_field_fullname.split('.')[1];\n write_requires_master_read = (ref = Creator.getObject(reObjectName)) != null ? (ref1 = ref.fields[reFieldName]) != null ? ref1.write_requires_master_read : void 0 : void 0;\n related = {\n object_name: reObjectName,\n columns: item.field_names,\n mobile_columns: item.field_names,\n is_file: reObjectName === \"cms_files\",\n filtersFunction: item.filters,\n sort: item.sort,\n related_field_name: reFieldName,\n customRelatedListObject: true,\n write_requires_master_read: write_requires_master_read,\n label: item.label,\n actions: item.buttons,\n visible_on: item.visible_on,\n page_size: item.page_size\n };\n return objectLayoutRelatedListObjects.push(related);\n });\n return objectLayoutRelatedListObjects;\n }\n relatedList = _object.relatedList;\n if (!_.isEmpty(relatedList)) {\n _.each(relatedList, function(objOrName) {\n var related;\n if (_.isObject(objOrName)) {\n related = {\n object_name: objOrName.objectName,\n columns: objOrName.columns,\n mobile_columns: objOrName.mobile_columns,\n is_file: objOrName.objectName === \"cms_files\",\n filtersFunction: objOrName.filters,\n sort: objOrName.sort,\n related_field_name: '',\n customRelatedListObject: true,\n label: objOrName.label,\n actions: objOrName.actions,\n page_size: objOrName.page_size\n };\n relatedListObjects[objOrName.objectName] = related;\n return relatedListNames.push(objOrName.objectName);\n } else if (_.isString(objOrName)) {\n return relatedListNames.push(objOrName);\n }\n });\n }\n }\n mapList = {};\n related_objects = Creator.getRelatedObjects(object_name);\n _.each(related_objects, function(related_object_item) {\n var columns, mobile_columns, order, related, relatedObject, related_field_name, related_object, related_object_name, tabular_order, write_requires_master_read;\n if (!(related_object_item != null ? related_object_item.object_name : void 0)) {\n return;\n }\n related_object_name = related_object_item.object_name;\n related_field_name = related_object_item.foreign_key;\n write_requires_master_read = related_object_item.write_requires_master_read;\n related_object = Creator.getObject(related_object_name);\n if (!related_object) {\n return;\n }\n columns = Creator.getObjectFirstListViewColumns(related_object_name) || [\"name\"];\n columns = _.without(columns, related_field_name);\n mobile_columns = Creator.getObjectFirstListViewColumns(related_object_name, true) || [\"name\"];\n mobile_columns = _.without(mobile_columns, related_field_name);\n order = Creator.getObjectDefaultSort(related_object_name);\n tabular_order = Creator.transformSortToTabular(order, columns);\n if (/\\w+\\.\\$\\.\\w+/g.test(related_field_name)) {\n related_field_name = related_field_name.replace(/\\$\\./, \"\");\n }\n related = {\n object_name: related_object_name,\n columns: columns,\n mobile_columns: mobile_columns,\n related_field_name: related_field_name,\n is_file: related_object_name === \"cms_files\",\n write_requires_master_read: write_requires_master_read\n };\n relatedObject = relatedListObjects[related_object_name];\n if (relatedObject) {\n if (relatedObject.columns) {\n related.columns = relatedObject.columns;\n }\n if (relatedObject.mobile_columns) {\n related.mobile_columns = relatedObject.mobile_columns;\n }\n if (relatedObject.sort) {\n related.sort = relatedObject.sort;\n }\n if (relatedObject.filtersFunction) {\n related.filtersFunction = relatedObject.filtersFunction;\n }\n if (relatedObject.customRelatedListObject) {\n related.customRelatedListObject = relatedObject.customRelatedListObject;\n }\n if (relatedObject.label) {\n related.label = relatedObject.label;\n }\n if (relatedObject.page_size) {\n related.page_size = relatedObject.page_size;\n }\n delete relatedListObjects[related_object_name];\n }\n return mapList[related.object_name] = related;\n });\n spaceId = Session.get(\"spaceId\");\n userId = Meteor.userId();\n related_object_names = _.pluck(_.values(relatedListObjects), \"object_name\");\n permissions = Creator.getPermissions(object_name, spaceId, userId);\n unrelated_objects = permissions.unrelated_objects;\n related_object_names = _.difference(related_object_names, unrelated_objects);\n _.each(relatedListObjects, function(v, related_object_name) {\n var allowRead, isActive, ref;\n isActive = related_object_names.indexOf(related_object_name) > -1;\n allowRead = (ref = Creator.getPermissions(related_object_name, spaceId, userId)) != null ? ref.allowRead : void 0;\n if (isActive && allowRead) {\n return mapList[related_object_name] = v;\n }\n });\n list = [];\n if (_.isEmpty(relatedListNames)) {\n list = _.values(mapList);\n } else {\n _.each(relatedListNames, function(objectName) {\n if (mapList[objectName]) {\n return list.push(mapList[objectName]);\n }\n });\n }\n if (_.has(_object, 'allow_relatedList')) {\n list = _.filter(list, function(item) {\n return _.include(_object.allow_relatedList, item.object_name);\n });\n }\n return list;\n };\n}\n\nCreator.getObjectFirstListView = function(object_name) {\n return _.first(Creator.getListViews(object_name));\n};\n\n\n/* \n\t取出list_view_id对应的视图,如果不存在或者没有权限,就返回第一个视图\n\texac为true时,需要强制按list_view_id精确查找,不默认返回第一个视图\n */\n\nCreator.getListView = function(object_name, list_view_id, exac) {\n var listViews, list_view, object;\n if (Meteor.isClient) {\n if (!object_name) {\n object_name = Session.get(\"object_name\");\n }\n if (!list_view_id) {\n list_view_id = Session.get(\"list_view_id\");\n }\n }\n object = Creator.getObject(object_name);\n if (!object) {\n return;\n }\n listViews = Creator.getListViews(object_name);\n if (!(listViews != null ? listViews.length : void 0)) {\n return;\n }\n list_view = _.find(listViews, function(item) {\n return item._id === list_view_id || item.name === list_view_id;\n });\n if (!list_view) {\n if (exac) {\n return;\n } else {\n list_view = listViews[0];\n }\n }\n return list_view;\n};\n\nCreator.getListViewIsRecent = function(object_name, list_view_id) {\n var listView, object;\n if (Meteor.isClient) {\n if (!object_name) {\n object_name = Session.get(\"object_name\");\n }\n if (!list_view_id) {\n list_view_id = Session.get(\"list_view_id\");\n }\n }\n if (typeof list_view_id === \"string\") {\n object = Creator.getObject(object_name);\n if (!object) {\n return;\n }\n listView = _.findWhere(object.list_views, {\n _id: list_view_id\n });\n } else {\n listView = list_view_id;\n }\n return (listView != null ? listView.name : void 0) === \"recent\";\n};\n\n\n/*\n 从columns参数中过滤出用于手机端显示的columns\n\t规则:\n\t1.优先把columns中的name字段排在第一个\n\t2.最多只返回4个字段\n\t3.考虑宽字段占用整行规则条件下,最多只返回两行\n */\n\nCreator.pickObjectMobileColumns = function(object_name, columns) {\n var count, field, fields, getField, isNameColumn, itemCount, maxCount, maxRows, nameColumn, nameKey, object, result;\n result = [];\n maxRows = 2;\n maxCount = maxRows * 2;\n count = 0;\n object = Creator.getObject(object_name);\n fields = object.fields;\n if (!object) {\n return columns;\n }\n nameKey = object.NAME_FIELD_KEY;\n isNameColumn = function(item) {\n if (_.isObject(item)) {\n return item.field === nameKey;\n } else {\n return item === nameKey;\n }\n };\n getField = function(item) {\n if (_.isObject(item)) {\n return fields[item.field];\n } else {\n return fields[item];\n }\n };\n if (nameKey) {\n nameColumn = columns.find(function(item) {\n return isNameColumn(item);\n });\n }\n if (nameColumn) {\n field = getField(nameColumn);\n itemCount = field.is_wide ? 2 : 1;\n count += itemCount;\n result.push(nameColumn);\n }\n columns.forEach(function(item) {\n field = getField(item);\n if (!field) {\n return;\n }\n itemCount = field.is_wide ? 2 : 1;\n if (count < maxCount && result.length < maxCount && !isNameColumn(item)) {\n count += itemCount;\n if (count <= maxCount) {\n return result.push(item);\n }\n }\n });\n return result;\n};\n\n\n/*\n 获取默认视图\n */\n\nCreator.getObjectDefaultView = function(object_name) {\n var defaultView, object, ref;\n object = Creator.getObject(object_name);\n if (!object) {\n object = Creator.Objects[object_name];\n }\n if (object != null ? (ref = object.list_views) != null ? ref[\"default\"] : void 0 : void 0) {\n defaultView = object.list_views[\"default\"];\n } else {\n _.each(object != null ? object.list_views : void 0, function(list_view, key) {\n if (list_view.name === \"all\" || key === \"all\") {\n return defaultView = list_view;\n }\n });\n }\n return defaultView;\n};\n\n\n/*\n 获取对象的列表默认显示字段\n */\n\nCreator.getObjectDefaultColumns = function(object_name, use_mobile_columns) {\n var columns, defaultView;\n defaultView = Creator.getObjectDefaultView(object_name);\n columns = defaultView != null ? defaultView.columns : void 0;\n if (use_mobile_columns) {\n if (defaultView != null ? defaultView.mobile_columns : void 0) {\n columns = defaultView.mobile_columns;\n } else if (columns) {\n columns = Creator.pickObjectMobileColumns(object_name, columns);\n }\n }\n return columns;\n};\n\n\n/*\n 获取对象的列表第一个视图显示的字段\n */\n\nCreator.getObjectFirstListViewColumns = function(object_name, use_mobile_columns) {\n var columns, defaultView;\n defaultView = Creator.getObjectFirstListView(object_name);\n columns = defaultView != null ? defaultView.columns : void 0;\n if (use_mobile_columns) {\n if (defaultView != null ? defaultView.mobile_columns : void 0) {\n columns = defaultView.mobile_columns;\n } else if (columns) {\n columns = Creator.pickObjectMobileColumns(object_name, columns);\n }\n }\n return columns;\n};\n\n\n/*\n\t获取对象的列表默认额外加载的字段\n */\n\nCreator.getObjectDefaultExtraColumns = function(object_name) {\n var defaultView;\n defaultView = Creator.getObjectDefaultView(object_name);\n return defaultView != null ? defaultView.extra_columns : void 0;\n};\n\n\n/*\n\t获取对象的默认排序\n */\n\nCreator.getObjectDefaultSort = function(object_name) {\n var defaultView;\n defaultView = Creator.getObjectDefaultView(object_name);\n if (defaultView) {\n if (defaultView.sort) {\n return defaultView.sort;\n } else {\n return [[\"created\", \"desc\"]];\n }\n }\n};\n\n\n/*\n 判断是否All view\n */\n\nCreator.isAllView = function(list_view) {\n return (list_view != null ? list_view.name : void 0) === \"all\";\n};\n\n\n/*\n 判断是否最近查看 view\n */\n\nCreator.isRecentView = function(list_view) {\n return (list_view != null ? list_view.name : void 0) === \"recent\";\n};\n\n\n/*\n 将sort转换为Tabular控件所需要的格式\n */\n\nCreator.transformSortToTabular = function(sort, tabularColumns) {\n var tabular_sort;\n tabular_sort = [];\n _.each(sort, function(item) {\n var column_index, field_name, order;\n if (_.isArray(item)) {\n if (item.length === 1) {\n column_index = tabularColumns.indexOf(item[0]);\n if (column_index > -1) {\n return tabular_sort.push([column_index, \"asc\"]);\n }\n } else if (item.length === 2) {\n column_index = tabularColumns.indexOf(item[0]);\n if (column_index > -1) {\n return tabular_sort.push([column_index, item[1]]);\n }\n }\n } else if (_.isObject(item)) {\n field_name = item.field_name;\n order = item.order;\n if (field_name && order) {\n column_index = tabularColumns.indexOf(field_name);\n if (column_index > -1) {\n return tabular_sort.push([column_index, order]);\n }\n }\n }\n });\n return tabular_sort;\n};\n\n\n/*\n 将sort转换为DevExpress控件所需要的格式\n */\n\nCreator.transformSortToDX = function(sort) {\n var dx_sort;\n dx_sort = [];\n _.each(sort, function(item) {\n var field_name, order;\n if (_.isArray(item)) {\n return dx_sort.push(item);\n } else if (_.isObject(item)) {\n field_name = item.field_name;\n order = item.order;\n if (field_name && order) {\n return dx_sort.push([field_name, order]);\n }\n }\n });\n return dx_sort;\n};\n","SimpleSchema.RegEx.code = new RegExp('^[a-zA-Z_][a-zA-Z0-9_]*$')\n\nif Meteor.isClient\n\tMeteor.startup ()->\n\t\t_regExMessages = SimpleSchema._globalMessages.regEx || []\n\t\t_regExMessages.push {exp: SimpleSchema.RegEx.code, msg: \"[label] 只能以字母、_开头,且只能包含字母、数字、_\"}\n\t\tSimpleSchema.messages({\n\t\t\tregEx: _regExMessages,\n\t\t})","SimpleSchema.RegEx.code = new RegExp('^[a-zA-Z_][a-zA-Z0-9_]*$');\n\nif (Meteor.isClient) {\n Meteor.startup(function() {\n var _regExMessages;\n _regExMessages = SimpleSchema._globalMessages.regEx || [];\n _regExMessages.push({\n exp: SimpleSchema.RegEx.code,\n msg: \"[label] 只能以字母、_开头,且只能包含字母、数字、_\"\n });\n return SimpleSchema.messages({\n regEx: _regExMessages\n });\n });\n}\n","SimpleSchema.RegEx.field = new RegExp('^[a-zA-Z_]\\\\w*(\\\\.\\\\$\\\\.\\\\w+)?[a-zA-Z0-9]*$')\n\nif Meteor.isClient\n\tMeteor.startup ()->\n\t\t_regExMessages = SimpleSchema._globalMessages.regEx || []\n\t\t_regExMessages.push {exp: SimpleSchema.RegEx.field, msg: \"[label] 只能以字母、_开头,.$.前后必须包含字符\"}\n\t\tSimpleSchema.messages({\n\t\t\tregEx: _regExMessages,\n\t\t})","SimpleSchema.RegEx.field = new RegExp('^[a-zA-Z_]\\\\w*(\\\\.\\\\$\\\\.\\\\w+)?[a-zA-Z0-9]*$');\n\nif (Meteor.isClient) {\n Meteor.startup(function() {\n var _regExMessages;\n _regExMessages = SimpleSchema._globalMessages.regEx || [];\n _regExMessages.push({\n exp: SimpleSchema.RegEx.field,\n msg: \"[label] 只能以字母、_开头,.$.前后必须包含字符\"\n });\n return SimpleSchema.messages({\n regEx: _regExMessages\n });\n });\n}\n","// 因为meteor编译coffeescript会导致eval函数报错,所以单独写在一个js文件中。\nCreator.evalInContext = function(js, context) {\n //# Return the results of the in-line anonymous function we .call with the passed context\n return function() { \n \treturn eval(js); \n\t}.call(context);\n}\n\n\nCreator.eval = function(js){\n\ttry{\n\t\treturn eval(js)\n\t}catch (e){\n\t\tconsole.error(e, js);\n\t}\n};","\tgetOption = (option)->\n\t\tfoo = option.split(\":\")\n\t\tif foo.length > 2\n\t\t\treturn {label: foo[0], value: foo[1], color: foo[2]}\n\t\telse if foo.length > 1\n\t\t\treturn {label: foo[0], value: foo[1]}\n\t\telse\n\t\t\treturn {label: foo[0], value: foo[0]}\n\n\tconvertField = (object_name, field_name, field, spaceId)->\n\t\tif Meteor.isServer && spaceId && field.type == 'select'\n\t\t\tcode = field.picklist || \"#{object_name}.#{field_name}\";\n\t\t\tif code\n\t\t\t\tpicklist = Creator.getPicklist(code, spaceId);\n\t\t\t\tif picklist\n\t\t\t\t\toptions = [];\n\t\t\t\t\tallOptions = [];\n\t\t\t\t\tpicklistOptions = Creator.getPickListOptions(picklist)\n\t\t\t\t\tpicklistOptions = _.sortBy(picklistOptions, 'sort_no')?.reverse();\n\t\t\t\t\t_.each picklistOptions, (item)->\n\t\t\t\t\t\tlabel = item.name\n\t\t\t\t\t\tvalue = item.value || item.name\n\t\t\t\t\t\tallOptions.push({label: label, value: value, enable: item.enable, color: item.color})\n\t\t\t\t\t\tif item.enable\n\t\t\t\t\t\t\toptions.push({label: label, value: value, color: item.color})\n\t\t\t\t\t\tif item.default\n\t\t\t\t\t\t\tfield.defaultValue = value\n\t\t\t\t\tif options.length > 0\n\t\t\t\t\t\tfield.options = options\n\t\t\t\t\tif allOptions.length > 0\n\t\t\t\t\t\tfield.allOptions = allOptions\n\t\treturn field;\n\n\tCreator.convertObject = (object, spaceId)->\n\t\tif !object\n\t\t\treturn\n\t\t_.forEach object.triggers, (trigger, key)->\n\n\t\t\tif (Meteor.isServer && trigger.on == \"server\") || (Meteor.isClient && trigger.on == \"client\")\n\t\t\t\t_todo_from_code = trigger?._todo\n\t\t\t\t_todo_from_db = trigger.todo\n\t\t\t\tif _todo_from_code && _.isString(_todo_from_code)\n\t\t\t\t\ttrigger.todo = Creator.eval(\"(#{_todo_from_code})\")\n\n\t\t\t\tif _todo_from_db && _.isString(_todo_from_db)\n\t\t\t\t\t#只有update时, fieldNames, modifier, options 才有值\n\t\t\t\t\t#TODO 控制可使用的变量,尤其是Collection\n\t\t\t\t\tif _todo_from_db.startsWith(\"function\")\n\t\t\t\t\t\ttrigger.todo = Creator.eval(\"(#{_todo_from_db})\")\n\t\t\t\t\telse\n\t\t\t\t\t\ttrigger.todo = Creator.eval(\"(function(userId, doc, fieldNames, modifier, options){#{_todo_from_db}})\")\n\n\t\t\tif Meteor.isServer && trigger.on == \"client\"\n\t\t\t\t_todo = trigger.todo\n\t\t\t\tif _todo && _.isFunction(_todo)\n\t\t\t\t\ttrigger._todo = _todo.toString()\n\n\t\tif Meteor.isClient\n\t\t\t_.forEach object.fields, (field, key)->\n\n\t\t\t\tif field.omit\n\t\t\t\t\t# omit字段完全隐藏不显示\n\t\t\t\t\tfield.hidden = true\n\n\t\t\t\tif field.required && field.readonly\n\t\t\t\t\t# 通用必填字段 #2952,必填字段设置为非只读\n\t\t\t\t\tfield.readonly = false\n\n\t\t\t\tsystemBaseFields = Creator.getSystemBaseFields()\n\t\t\t\tif systemBaseFields.indexOf(key) > -1\n\t\t\t\t\t# 强制创建人创建时间等字段为只读\n\t\t\t\t\tfield.readonly = true\n\n\t\t\t_.forEach object.actions, (action, key)->\n\t\t\t\t_todo_from_code = action?._todo\n\t\t\t\t_todo_from_db = action?.todo\n\t\t\t\tif _todo_from_code && _.isString(_todo_from_code)\n\t\t\t\t\t#TODO 控制可使用的变量\n\t\t\t\t\ttry\n\t\t\t\t\t\taction.todo = Creator.eval(\"(#{_todo_from_code})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"todo_from_code\", _todo_from_code\n\t\t\t\tif _todo_from_db && _.isString(_todo_from_db)\n\t\t\t\t\t#TODO 控制可使用的变量\n\t\t\t\t\ttry\n\t\t\t\t\t\tif _todo_from_db.startsWith(\"function\")\n\t\t\t\t\t\t\taction.todo = Creator.eval(\"(#{_todo_from_db})\")\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tif _.isFunction(Creator.actionsByName[_todo_from_db])\n\t\t\t\t\t\t\t\taction.todo = _todo_from_db\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\taction.todo = Creator.eval(\"(function(){#{_todo_from_db}})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"todo_from_db\", _todo_from_db, error\n\n\t\t\t\t_visible = action?._visible\n\t\t\t\tif _visible\n\t\t\t\t\ttry\n\t\t\t\t\t\tif _.isString(_visible)\n\t\t\t\t\t\t\t_visible = _visible.trim()\n\t\t\t\t\t\tif Steedos.isExpression(_visible)\n\t\t\t\t\t\t\t# 支持页面布局中写visible_on函数表达式,页面布局按钮的显示条件不生效 #3340\n\t\t\t\t\t\t\taction.visible = (object_name, record_id, record_permissions, record) ->\n\t\t\t\t\t\t\t\tglobalData = Object.assign({}, Creator.USER_CONTEXT, {now: new Date()})\n\t\t\t\t\t\t\t\treturn Steedos.parseSingleExpression(_visible, record, \"#\", globalData)\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\taction.visible = Creator.eval(\"(#{_visible})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"action.visible to function error: \", error, _visible\n\t\telse\n\t\t\t_.forEach object.actions, (action, key)->\n\t\t\t\t_todo = action?.todo\n\t\t\t\tif _todo && _.isFunction(_todo)\n\t\t\t\t\t#TODO 控制可使用的变量\n\t\t\t\t\taction._todo = _todo.toString()\n\n\t\t\t\t_visible = action?.visible\n\n\t\t\t\tif _visible && _.isFunction(_visible)\n\t\t\t\t\taction._visible = _visible.toString()\n\n\t\t_.forEach object.fields, (field, key)->\n\n\t\t\tfield = convertField(object.name, key, field, spaceId);\n\n\t\t\tif field.options && _.isString(field.options)\n\t\t\t\ttry\n\t\t\t\t\t_options = []\n\t\t\t\t\t#支持\\n或者英文逗号分割,\n\t\t\t\t\t_.forEach field.options.split(\"\\n\"), (option)->\n\t\t\t\t\t\tif option.indexOf(\",\")\n\t\t\t\t\t\t\toptions = option.split(\",\")\n\t\t\t\t\t\t\t_.forEach options, (_option)->\n\t\t\t\t\t\t\t\t_options.push(getOption(_option))\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t_options.push(getOption(option))\n\t\t\t\t\tfield.options = _options\n\t\t\t\tcatch error\n\t\t\t\t\tconsole.error \"Creator.convertFieldsOptions\", field.options, error\n\n\t\t\telse if field.options && _.isArray(field.options)\n\t\t\t\ttry\n\t\t\t\t\t_options = []\n\t\t\t\t\t#支持数组中直接定义每个选项的简版格式字符串\n\t\t\t\t\t_.forEach field.options, (option)->\n\t\t\t\t\t\tif _.isString(option)\n\t\t\t\t\t\t\t_options.push(getOption(option))\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t_options.push(option)\n\t\t\t\t\tfield.options = _options\n\t\t\t\tcatch error\n\t\t\t\t\tconsole.error \"Creator.convertFieldsOptions\", field.options, error\n\n\t\t\telse if field.options && !_.isFunction(field.options) && !_.isArray(field.options) && _.isObject(field.options)\n\t\t\t\t_options = []\n\t\t\t\t_.each field.options, (v, k)->\n\t\t\t\t\t_options.push {label: v, value: k}\n\t\t\t\tfield.options = _options\n\n\t\t\tif Meteor.isServer\n\t\t\t\toptions = field.options\n\t\t\t\tif options && _.isFunction(options)\n\t\t\t\t\tfield._options = field.options.toString()\n\t\t\telse\n\t\t\t\toptions = field._options\n\t\t\t\tif options && _.isString(options)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.options = Creator.eval(\"(#{options})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t\tif Meteor.isServer\n\t\t\t\tregEx = field.regEx\n\t\t\t\tif regEx\n\t\t\t\t\tfield._regEx = field.regEx.toString()\n\t\t\telse\n\t\t\t\tregEx = field._regEx\n\t\t\t\tif regEx\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.regEx = Creator.eval(\"(#{regEx})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t\tif Meteor.isServer\n\t\t\t\tmin = field.min\n\t\t\t\tif _.isFunction(min)\n\t\t\t\t\tfield._min = min.toString()\n\t\t\telse\n\t\t\t\tmin = field._min\n\t\t\t\tif _.isString(min)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.min = Creator.eval(\"(#{min})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t\tif Meteor.isServer\n\t\t\t\tmax = field.max\n\t\t\t\tif _.isFunction(max)\n\t\t\t\t\tfield._max = max.toString()\n\t\t\telse\n\t\t\t\tmax = field._max\n\t\t\t\tif _.isString(max)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.max = Creator.eval(\"(#{max})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t\tif Meteor.isServer\n\t\t\t\tif field.autoform\n\t\t\t\t\t_type = field.autoform.type\n\t\t\t\t\tif _type && _.isFunction(_type) && _type != Object && _type != String && _type != Number && _type != Boolean && !_.isArray(_type)\n\t\t\t\t\t\tfield.autoform._type = _type.toString()\n\t\t\telse\n\t\t\t\tif field.autoform\n\t\t\t\t\t_type = field.autoform._type\n\t\t\t\t\tif _type && _.isString(_type)\n\t\t\t\t\t\ttry\n\t\t\t\t\t\t\tfield.autoform.type = Creator.eval(\"(#{_type})\")\n\t\t\t\t\t\tcatch error\n\t\t\t\t\t\t\tconsole.error \"convert field -> type error\", field, error\n\n\t\t\tif Meteor.isServer\n\n\t\t\t\toptionsFunction = field.optionsFunction\n\t\t\t\treference_to = field.reference_to\n\t\t\t\tcreateFunction = field.createFunction\n\t\t\t\tbeforeOpenFunction = field.beforeOpenFunction\n\t\t\t\tfiltersFunction = field.filtersFunction\n\n\t\t\t\tif optionsFunction && _.isFunction(optionsFunction)\n\t\t\t\t\tfield._optionsFunction = optionsFunction.toString()\n\n\t\t\t\tif reference_to && _.isFunction(reference_to)\n\t\t\t\t\tfield._reference_to = reference_to.toString()\n\n\t\t\t\tif createFunction && _.isFunction(createFunction)\n\t\t\t\t\tfield._createFunction = createFunction.toString()\n\t\t\t\tif beforeOpenFunction && _.isFunction(beforeOpenFunction)\n\t\t\t\t\tfield._beforeOpenFunction = beforeOpenFunction.toString()\n\n\t\t\t\tif filtersFunction && _.isFunction(filtersFunction)\n\t\t\t\t\tfield._filtersFunction = filtersFunction.toString()\n\t\t\telse\n\n\t\t\t\toptionsFunction = field._optionsFunction || field.optionsFunction\n\t\t\t\treference_to = field._reference_to\n\t\t\t\tcreateFunction = field._createFunction\n\t\t\t\tbeforeOpenFunction = field._beforeOpenFunction\n\t\t\t\tfiltersFunction = field._filtersFunction || field.filtersFunction\n\n\t\t\t\tif optionsFunction && _.isString(optionsFunction)\n\t\t\t\t\tfield.optionsFunction = Creator.eval(\"(#{optionsFunction})\")\n\n\t\t\t\tif reference_to && _.isString(reference_to)\n\t\t\t\t\tfield.reference_to = Creator.eval(\"(#{reference_to})\")\n\n\t\t\t\tif createFunction && _.isString(createFunction)\n\t\t\t\t\tfield.createFunction = Creator.eval(\"(#{createFunction})\")\n\n\t\t\t\tif beforeOpenFunction && _.isString(beforeOpenFunction)\n\t\t\t\t\tfield.beforeOpenFunction = Creator.eval(\"(#{beforeOpenFunction})\")\n\n\t\t\t\tif filtersFunction && _.isString(filtersFunction)\n\t\t\t\t\tfield.filtersFunction = Creator.eval(\"(#{filtersFunction})\")\n\n\t\t\tif Meteor.isServer\n\t\t\t\tdefaultValue = field.defaultValue\n\t\t\t\tif defaultValue && _.isFunction(defaultValue)\n\t\t\t\t\tfield._defaultValue = field.defaultValue.toString()\n\t\t\telse\n\t\t\t\tdefaultValue = field._defaultValue\n\n\t\t\t\tif !defaultValue && _.isString(field.defaultValue) && field.defaultValue.startsWith(\"function\")\n\t\t\t\t\tdefaultValue = field.defaultValue\n\n\t\t\t\tif defaultValue && _.isString(defaultValue)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.defaultValue = Creator.eval(\"(#{defaultValue})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\t\t\t\n\t\t\tif Meteor.isServer\n\t\t\t\tis_company_limited = field.is_company_limited\n\t\t\t\tif is_company_limited && _.isFunction(is_company_limited)\n\t\t\t\t\tfield._is_company_limited = field.is_company_limited.toString()\n\t\t\telse\n\t\t\t\tis_company_limited = field._is_company_limited\n\t\t\t\tif is_company_limited && _.isString(is_company_limited)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.is_company_limited = Creator.eval(\"(#{is_company_limited})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t_.forEach object.list_views, (list_view, key) ->\n\t\t\t###\n\t\t\t视图过虑器需要支持function,后台转成字符串,前台eval成函数\n\t\t\t让过虑器支持两种function方式:\n\t\t\t1. 整个filters为function:\n\t\t\t如:\n\t\t\tfilters: ()->\n\t\t\t\treturn [[[\"object_name\",\"=\",\"project_issues\"],'or',[\"object_name\",\"=\",\"tasks\"]]]\n\t\t\t2. filters内的filter.value为function\n\t\t\t如:\n\t\t\tfilters: [[\"object_name\", \"=\", ()->\n\t\t\t\treturn \"project_issues\"\n\t\t\t]]\n\t\t\t或\n\t\t\tfilters: [{\n\t\t\t\t\"field\": \"object_name\"\n\t\t\t\t\"operation\": \"=\"\n\t\t\t\t\"value\": ()->\n\t\t\t\t\treturn \"project_issues\"\n\t\t\t}]\n\t\t\t###\n\t\t\tif _.isFunction(list_view.filters)\n\t\t\t\tif Meteor.isServer\n\t\t\t\t\tlist_view._filters = list_view.filters.toString()\n\t\t\telse if _.isString(list_view._filters)\n\t\t\t\tif Meteor.isClient\n\t\t\t\t\tlist_view.filters = Creator.eval(\"(#{list_view._filters})\")\n\t\t\telse\n\t\t\t\t_.forEach list_view.filters, (filter, _index)->\n\t\t\t\t\tif _.isArray(filter)\n\t\t\t\t\t\tif Meteor.isServer\n\t\t\t\t\t\t\tif filter.length == 3 and _.isFunction(filter[2])\n\t\t\t\t\t\t\t\tfilter[2] = filter[2].toString()\n\t\t\t\t\t\t\t\tfilter[3] = \"FUNCTION\"\n\t\t\t\t\t\t\telse if filter.length == 3 and _.isDate(filter[2])\n\t\t\t\t\t\t\t\t# 如果是Date类型,则filter[2]值到前端会自动转成字符串,格式:\"2018-03-29T03:43:21.787Z\"\n\t\t\t\t\t\t\t\t# 包括grid列表请求的接口在内的所有OData接口,Date类型字段都会以上述格式返回\n\t\t\t\t\t\t\t\tfilter[3] = \"DATE\"\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tif filter.length == 4 and _.isString(filter[2]) and filter[3] == \"FUNCTION\"\n\t\t\t\t\t\t\t\tfilter[2] = Creator.eval(\"(#{filter[2]})\")\n\t\t\t\t\t\t\t\tfilter.pop()\n\t\t\t\t\t\t\tif filter.length == 4 and _.isString(filter[2]) and filter[3] == \"DATE\"\n\t\t\t\t\t\t\t\tfilter[2] = new Date(filter[2])\n\t\t\t\t\t\t\t\tfilter.pop()\n\t\t\t\t\telse if _.isObject(filter)\n\t\t\t\t\t\tif Meteor.isServer\n\t\t\t\t\t\t\tif _.isFunction(filter?.value)\n\t\t\t\t\t\t\t\tfilter._value = filter.value.toString()\n\t\t\t\t\t\t\telse if _.isDate(filter?.value)\n\t\t\t\t\t\t\t\tfilter._is_date = true\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tif _.isString(filter?._value)\n\t\t\t\t\t\t\t\tfilter.value = Creator.eval(\"(#{filter._value})\")\n\t\t\t\t\t\t\telse if filter._is_date == true\n\t\t\t\t\t\t\t\tfilter.value = new Date(filter.value)\n\n\t\tif Meteor.isServer\n\t\t\tif object.form && !_.isString(object.form)\n\t\t\t\tobject.form = JSON.stringify object.form, (key, val)->\n\t\t\t\t\tif _.isFunction(val)\n\t\t\t\t\t\treturn val + '';\n\t\t\t\t\telse\n\t\t\t\t\t\treturn val;\n\t\telse if Meteor.isClient\n\t\t\tif object.form\n\t\t\t\tobject.form = JSON.parse object.form, (key, val)->\n\t\t\t\t\tif _.isString(val) && val.startsWith('function')\n\t\t\t\t\t\treturn Creator.eval(\"(#{val})\")\n\t\t\t\t\telse\n\t\t\t\t\t\treturn val;\n\n\t\tif Meteor.isClient\n\t\t\t_.forEach object.related_lists, (relatedObjInfo)->\n\t\t\t\tif _.isObject(relatedObjInfo)\n\t\t\t\t\t_.forEach relatedObjInfo, (val, key)->\n\t\t\t\t\t\tif key == 'filters' && _.isString(val)\n\t\t\t\t\t\t\ttry\n\t\t\t\t\t\t\t\trelatedObjInfo[key] = Creator.eval(\"(#{val})\")\n\t\t\t\t\t\t\tcatch error\n\t\t\t\t\t\t\t\tconsole.error \"filters_code\", val\n\t\telse\n\t\t\t_.forEach object.related_lists, (relatedObjInfo)->\n\t\t\t\tif _.isObject(relatedObjInfo)\n\t\t\t\t\t_.forEach relatedObjInfo, (val, key)->\n\t\t\t\t\t\tif key == 'filters' && _.isFunction(val)\n\t\t\t\t\t\t\trelatedObjInfo[key] = val.toString()\n\n\t\tif Meteor.isClient\n\t\t\t_.forEach object.relatedList, (relatedObjInfo)->\n\t\t\t\tif _.isObject(relatedObjInfo)\n\t\t\t\t\t_.forEach relatedObjInfo, (val, key)->\n\t\t\t\t\t\tif key == 'filters' && _.isString(val)\n\t\t\t\t\t\t\ttry\n\t\t\t\t\t\t\t\trelatedObjInfo[key] = Creator.eval(\"(#{val})\")\n\t\t\t\t\t\t\tcatch error\n\t\t\t\t\t\t\t\tconsole.error \"filters_code\", val\n\t\telse\n\t\t\t_.forEach object.relatedList, (relatedObjInfo)->\n\t\t\t\tif _.isObject(relatedObjInfo)\n\t\t\t\t\t_.forEach relatedObjInfo, (val, key)->\n\t\t\t\t\t\tif key == 'filters' && _.isFunction(val)\n\t\t\t\t\t\t\trelatedObjInfo[key] = val.toString()\n\n\t\treturn object\n\n\n","var convertField, getOption;\n\ngetOption = function(option) {\n var foo;\n foo = option.split(\":\");\n if (foo.length > 2) {\n return {\n label: foo[0],\n value: foo[1],\n color: foo[2]\n };\n } else if (foo.length > 1) {\n return {\n label: foo[0],\n value: foo[1]\n };\n } else {\n return {\n label: foo[0],\n value: foo[0]\n };\n }\n};\n\nconvertField = function(object_name, field_name, field, spaceId) {\n var allOptions, code, options, picklist, picklistOptions, ref;\n if (Meteor.isServer && spaceId && field.type === 'select') {\n code = field.picklist || (object_name + \".\" + field_name);\n if (code) {\n picklist = Creator.getPicklist(code, spaceId);\n if (picklist) {\n options = [];\n allOptions = [];\n picklistOptions = Creator.getPickListOptions(picklist);\n picklistOptions = (ref = _.sortBy(picklistOptions, 'sort_no')) != null ? ref.reverse() : void 0;\n _.each(picklistOptions, function(item) {\n var label, value;\n label = item.name;\n value = item.value || item.name;\n allOptions.push({\n label: label,\n value: value,\n enable: item.enable,\n color: item.color\n });\n if (item.enable) {\n options.push({\n label: label,\n value: value,\n color: item.color\n });\n }\n if (item[\"default\"]) {\n return field.defaultValue = value;\n }\n });\n if (options.length > 0) {\n field.options = options;\n }\n if (allOptions.length > 0) {\n field.allOptions = allOptions;\n }\n }\n }\n }\n return field;\n};\n\nCreator.convertObject = function(object, spaceId) {\n if (!object) {\n return;\n }\n _.forEach(object.triggers, function(trigger, key) {\n var _todo, _todo_from_code, _todo_from_db;\n if ((Meteor.isServer && trigger.on === \"server\") || (Meteor.isClient && trigger.on === \"client\")) {\n _todo_from_code = trigger != null ? trigger._todo : void 0;\n _todo_from_db = trigger.todo;\n if (_todo_from_code && _.isString(_todo_from_code)) {\n trigger.todo = Creator[\"eval\"](\"(\" + _todo_from_code + \")\");\n }\n if (_todo_from_db && _.isString(_todo_from_db)) {\n if (_todo_from_db.startsWith(\"function\")) {\n trigger.todo = Creator[\"eval\"](\"(\" + _todo_from_db + \")\");\n } else {\n trigger.todo = Creator[\"eval\"](\"(function(userId, doc, fieldNames, modifier, options){\" + _todo_from_db + \"})\");\n }\n }\n }\n if (Meteor.isServer && trigger.on === \"client\") {\n _todo = trigger.todo;\n if (_todo && _.isFunction(_todo)) {\n return trigger._todo = _todo.toString();\n }\n }\n });\n if (Meteor.isClient) {\n _.forEach(object.fields, function(field, key) {\n var systemBaseFields;\n if (field.omit) {\n field.hidden = true;\n }\n if (field.required && field.readonly) {\n field.readonly = false;\n }\n systemBaseFields = Creator.getSystemBaseFields();\n if (systemBaseFields.indexOf(key) > -1) {\n return field.readonly = true;\n }\n });\n _.forEach(object.actions, function(action, key) {\n var _todo_from_code, _todo_from_db, _visible, error;\n _todo_from_code = action != null ? action._todo : void 0;\n _todo_from_db = action != null ? action.todo : void 0;\n if (_todo_from_code && _.isString(_todo_from_code)) {\n try {\n action.todo = Creator[\"eval\"](\"(\" + _todo_from_code + \")\");\n } catch (error1) {\n error = error1;\n console.error(\"todo_from_code\", _todo_from_code);\n }\n }\n if (_todo_from_db && _.isString(_todo_from_db)) {\n try {\n if (_todo_from_db.startsWith(\"function\")) {\n action.todo = Creator[\"eval\"](\"(\" + _todo_from_db + \")\");\n } else {\n if (_.isFunction(Creator.actionsByName[_todo_from_db])) {\n action.todo = _todo_from_db;\n } else {\n action.todo = Creator[\"eval\"](\"(function(){\" + _todo_from_db + \"})\");\n }\n }\n } catch (error1) {\n error = error1;\n console.error(\"todo_from_db\", _todo_from_db, error);\n }\n }\n _visible = action != null ? action._visible : void 0;\n if (_visible) {\n try {\n if (_.isString(_visible)) {\n _visible = _visible.trim();\n }\n if (Steedos.isExpression(_visible)) {\n return action.visible = function(object_name, record_id, record_permissions, record) {\n var globalData;\n globalData = Object.assign({}, Creator.USER_CONTEXT, {\n now: new Date()\n });\n return Steedos.parseSingleExpression(_visible, record, \"#\", globalData);\n };\n } else {\n return action.visible = Creator[\"eval\"](\"(\" + _visible + \")\");\n }\n } catch (error1) {\n error = error1;\n return console.error(\"action.visible to function error: \", error, _visible);\n }\n }\n });\n } else {\n _.forEach(object.actions, function(action, key) {\n var _todo, _visible;\n _todo = action != null ? action.todo : void 0;\n if (_todo && _.isFunction(_todo)) {\n action._todo = _todo.toString();\n }\n _visible = action != null ? action.visible : void 0;\n if (_visible && _.isFunction(_visible)) {\n return action._visible = _visible.toString();\n }\n });\n }\n _.forEach(object.fields, function(field, key) {\n var _options, _type, beforeOpenFunction, createFunction, defaultValue, error, filtersFunction, is_company_limited, max, min, options, optionsFunction, reference_to, regEx;\n field = convertField(object.name, key, field, spaceId);\n if (field.options && _.isString(field.options)) {\n try {\n _options = [];\n _.forEach(field.options.split(\"\\n\"), function(option) {\n var options;\n if (option.indexOf(\",\")) {\n options = option.split(\",\");\n return _.forEach(options, function(_option) {\n return _options.push(getOption(_option));\n });\n } else {\n return _options.push(getOption(option));\n }\n });\n field.options = _options;\n } catch (error1) {\n error = error1;\n console.error(\"Creator.convertFieldsOptions\", field.options, error);\n }\n } else if (field.options && _.isArray(field.options)) {\n try {\n _options = [];\n _.forEach(field.options, function(option) {\n if (_.isString(option)) {\n return _options.push(getOption(option));\n } else {\n return _options.push(option);\n }\n });\n field.options = _options;\n } catch (error1) {\n error = error1;\n console.error(\"Creator.convertFieldsOptions\", field.options, error);\n }\n } else if (field.options && !_.isFunction(field.options) && !_.isArray(field.options) && _.isObject(field.options)) {\n _options = [];\n _.each(field.options, function(v, k) {\n return _options.push({\n label: v,\n value: k\n });\n });\n field.options = _options;\n }\n if (Meteor.isServer) {\n options = field.options;\n if (options && _.isFunction(options)) {\n field._options = field.options.toString();\n }\n } else {\n options = field._options;\n if (options && _.isString(options)) {\n try {\n field.options = Creator[\"eval\"](\"(\" + options + \")\");\n } catch (error1) {\n error = error1;\n console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n }\n }\n }\n if (Meteor.isServer) {\n regEx = field.regEx;\n if (regEx) {\n field._regEx = field.regEx.toString();\n }\n } else {\n regEx = field._regEx;\n if (regEx) {\n try {\n field.regEx = Creator[\"eval\"](\"(\" + regEx + \")\");\n } catch (error1) {\n error = error1;\n console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n }\n }\n }\n if (Meteor.isServer) {\n min = field.min;\n if (_.isFunction(min)) {\n field._min = min.toString();\n }\n } else {\n min = field._min;\n if (_.isString(min)) {\n try {\n field.min = Creator[\"eval\"](\"(\" + min + \")\");\n } catch (error1) {\n error = error1;\n console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n }\n }\n }\n if (Meteor.isServer) {\n max = field.max;\n if (_.isFunction(max)) {\n field._max = max.toString();\n }\n } else {\n max = field._max;\n if (_.isString(max)) {\n try {\n field.max = Creator[\"eval\"](\"(\" + max + \")\");\n } catch (error1) {\n error = error1;\n console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n }\n }\n }\n if (Meteor.isServer) {\n if (field.autoform) {\n _type = field.autoform.type;\n if (_type && _.isFunction(_type) && _type !== Object && _type !== String && _type !== Number && _type !== Boolean && !_.isArray(_type)) {\n field.autoform._type = _type.toString();\n }\n }\n } else {\n if (field.autoform) {\n _type = field.autoform._type;\n if (_type && _.isString(_type)) {\n try {\n field.autoform.type = Creator[\"eval\"](\"(\" + _type + \")\");\n } catch (error1) {\n error = error1;\n console.error(\"convert field -> type error\", field, error);\n }\n }\n }\n }\n if (Meteor.isServer) {\n optionsFunction = field.optionsFunction;\n reference_to = field.reference_to;\n createFunction = field.createFunction;\n beforeOpenFunction = field.beforeOpenFunction;\n filtersFunction = field.filtersFunction;\n if (optionsFunction && _.isFunction(optionsFunction)) {\n field._optionsFunction = optionsFunction.toString();\n }\n if (reference_to && _.isFunction(reference_to)) {\n field._reference_to = reference_to.toString();\n }\n if (createFunction && _.isFunction(createFunction)) {\n field._createFunction = createFunction.toString();\n }\n if (beforeOpenFunction && _.isFunction(beforeOpenFunction)) {\n field._beforeOpenFunction = beforeOpenFunction.toString();\n }\n if (filtersFunction && _.isFunction(filtersFunction)) {\n field._filtersFunction = filtersFunction.toString();\n }\n } else {\n optionsFunction = field._optionsFunction || field.optionsFunction;\n reference_to = field._reference_to;\n createFunction = field._createFunction;\n beforeOpenFunction = field._beforeOpenFunction;\n filtersFunction = field._filtersFunction || field.filtersFunction;\n if (optionsFunction && _.isString(optionsFunction)) {\n field.optionsFunction = Creator[\"eval\"](\"(\" + optionsFunction + \")\");\n }\n if (reference_to && _.isString(reference_to)) {\n field.reference_to = Creator[\"eval\"](\"(\" + reference_to + \")\");\n }\n if (createFunction && _.isString(createFunction)) {\n field.createFunction = Creator[\"eval\"](\"(\" + createFunction + \")\");\n }\n if (beforeOpenFunction && _.isString(beforeOpenFunction)) {\n field.beforeOpenFunction = Creator[\"eval\"](\"(\" + beforeOpenFunction + \")\");\n }\n if (filtersFunction && _.isString(filtersFunction)) {\n field.filtersFunction = Creator[\"eval\"](\"(\" + filtersFunction + \")\");\n }\n }\n if (Meteor.isServer) {\n defaultValue = field.defaultValue;\n if (defaultValue && _.isFunction(defaultValue)) {\n field._defaultValue = field.defaultValue.toString();\n }\n } else {\n defaultValue = field._defaultValue;\n if (!defaultValue && _.isString(field.defaultValue) && field.defaultValue.startsWith(\"function\")) {\n defaultValue = field.defaultValue;\n }\n if (defaultValue && _.isString(defaultValue)) {\n try {\n field.defaultValue = Creator[\"eval\"](\"(\" + defaultValue + \")\");\n } catch (error1) {\n error = error1;\n console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n }\n }\n }\n if (Meteor.isServer) {\n is_company_limited = field.is_company_limited;\n if (is_company_limited && _.isFunction(is_company_limited)) {\n return field._is_company_limited = field.is_company_limited.toString();\n }\n } else {\n is_company_limited = field._is_company_limited;\n if (is_company_limited && _.isString(is_company_limited)) {\n try {\n return field.is_company_limited = Creator[\"eval\"](\"(\" + is_company_limited + \")\");\n } catch (error1) {\n error = error1;\n return console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n }\n }\n }\n });\n _.forEach(object.list_views, function(list_view, key) {\n\n /*\n \t\t\t视图过虑器需要支持function,后台转成字符串,前台eval成函数\n \t\t\t让过虑器支持两种function方式:\n \t\t\t1. 整个filters为function:\n \t\t\t如:\n \t\t\tfilters: ()->\n \t\t\t\treturn [[[\"object_name\",\"=\",\"project_issues\"],'or',[\"object_name\",\"=\",\"tasks\"]]]\n \t\t\t2. filters内的filter.value为function\n \t\t\t如:\n \t\t\tfilters: [[\"object_name\", \"=\", ()->\n \t\t\t\treturn \"project_issues\"\n \t\t\t]]\n \t\t\t或\n \t\t\tfilters: [{\n \t\t\t\t\"field\": \"object_name\"\n \t\t\t\t\"operation\": \"=\"\n \t\t\t\t\"value\": ()->\n \t\t\t\t\treturn \"project_issues\"\n \t\t\t}]\n */\n if (_.isFunction(list_view.filters)) {\n if (Meteor.isServer) {\n return list_view._filters = list_view.filters.toString();\n }\n } else if (_.isString(list_view._filters)) {\n if (Meteor.isClient) {\n return list_view.filters = Creator[\"eval\"](\"(\" + list_view._filters + \")\");\n }\n } else {\n return _.forEach(list_view.filters, function(filter, _index) {\n if (_.isArray(filter)) {\n if (Meteor.isServer) {\n if (filter.length === 3 && _.isFunction(filter[2])) {\n filter[2] = filter[2].toString();\n return filter[3] = \"FUNCTION\";\n } else if (filter.length === 3 && _.isDate(filter[2])) {\n return filter[3] = \"DATE\";\n }\n } else {\n if (filter.length === 4 && _.isString(filter[2]) && filter[3] === \"FUNCTION\") {\n filter[2] = Creator[\"eval\"](\"(\" + filter[2] + \")\");\n filter.pop();\n }\n if (filter.length === 4 && _.isString(filter[2]) && filter[3] === \"DATE\") {\n filter[2] = new Date(filter[2]);\n return filter.pop();\n }\n }\n } else if (_.isObject(filter)) {\n if (Meteor.isServer) {\n if (_.isFunction(filter != null ? filter.value : void 0)) {\n return filter._value = filter.value.toString();\n } else if (_.isDate(filter != null ? filter.value : void 0)) {\n return filter._is_date = true;\n }\n } else {\n if (_.isString(filter != null ? filter._value : void 0)) {\n return filter.value = Creator[\"eval\"](\"(\" + filter._value + \")\");\n } else if (filter._is_date === true) {\n return filter.value = new Date(filter.value);\n }\n }\n }\n });\n }\n });\n if (Meteor.isServer) {\n if (object.form && !_.isString(object.form)) {\n object.form = JSON.stringify(object.form, function(key, val) {\n if (_.isFunction(val)) {\n return val + '';\n } else {\n return val;\n }\n });\n }\n } else if (Meteor.isClient) {\n if (object.form) {\n object.form = JSON.parse(object.form, function(key, val) {\n if (_.isString(val) && val.startsWith('function')) {\n return Creator[\"eval\"](\"(\" + val + \")\");\n } else {\n return val;\n }\n });\n }\n }\n if (Meteor.isClient) {\n _.forEach(object.related_lists, function(relatedObjInfo) {\n if (_.isObject(relatedObjInfo)) {\n return _.forEach(relatedObjInfo, function(val, key) {\n var error;\n if (key === 'filters' && _.isString(val)) {\n try {\n return relatedObjInfo[key] = Creator[\"eval\"](\"(\" + val + \")\");\n } catch (error1) {\n error = error1;\n return console.error(\"filters_code\", val);\n }\n }\n });\n }\n });\n } else {\n _.forEach(object.related_lists, function(relatedObjInfo) {\n if (_.isObject(relatedObjInfo)) {\n return _.forEach(relatedObjInfo, function(val, key) {\n if (key === 'filters' && _.isFunction(val)) {\n return relatedObjInfo[key] = val.toString();\n }\n });\n }\n });\n }\n if (Meteor.isClient) {\n _.forEach(object.relatedList, function(relatedObjInfo) {\n if (_.isObject(relatedObjInfo)) {\n return _.forEach(relatedObjInfo, function(val, key) {\n var error;\n if (key === 'filters' && _.isString(val)) {\n try {\n return relatedObjInfo[key] = Creator[\"eval\"](\"(\" + val + \")\");\n } catch (error1) {\n error = error1;\n return console.error(\"filters_code\", val);\n }\n }\n });\n }\n });\n } else {\n _.forEach(object.relatedList, function(relatedObjInfo) {\n if (_.isObject(relatedObjInfo)) {\n return _.forEach(relatedObjInfo, function(val, key) {\n if (key === 'filters' && _.isFunction(val)) {\n return relatedObjInfo[key] = val.toString();\n }\n });\n }\n });\n }\n return object;\n};\n","Creator.Formular = {}\n\nCreator.Formular.PREFIX = \"_VALUES\"\n\nCreator.Formular._prependPrefixForFormula = (prefix,fieldVariable)->\n\treg = /(\\{[^{}]*\\})/g;\n\n\trev = fieldVariable.replace reg, (m, $1)->\n\t\treturn prefix + $1.replace(/\\{\\s*/,\"[\\\"\").replace(/\\s*\\}/,\"\\\"]\").replace(/\\s*\\.\\s*/g,\"\\\"][\\\"\");\n\n\treturn rev\n\nCreator.Formular.checkFormula = (formula_str)->\n\tif _.isString(formula_str) && formula_str.indexOf(\"{\") > -1 && formula_str.indexOf(\"}\") > -1\n\t\treturn true\n\treturn false\n\nCreator.Formular.run = (formula_str, _CONTEXT, options)->\n\tif formula_str && _.isString(formula_str)\n\n\t\tif !_.isBoolean(options?.extend)\n\t\t\textend = true\n\n\t\t_VALUES = {}\n\t\t_VALUES = _.extend(_VALUES, _CONTEXT)\n\t\tif extend\n\t\t\t_VALUES = _.extend(_VALUES, Creator.getUserContext(options?.userId, options?.spaceId))\n\t\tformula_str = Creator.Formular._prependPrefixForFormula(\"this\", formula_str)\n\n\t\ttry\n\t\t\tdata = Creator.evalInContext(formula_str, _VALUES) # 此处不能用window.eval ,会导致变量作用域异常\n\t\t\treturn data\n\t\tcatch e\n\t\t\tconsole.error(\"Creator.Formular.run: #{formula_str}\", e)\n\t\t\tif Meteor.isClient\n\t\t\t\ttoastr?.error(\"公式执行出错了,请检查公式配置是否正确!\")\n\t\t\tthrow new Meteor.Error 500, \"Creator.Formular.run: #{formula_str}#{e}\"\n\n\treturn formula_str\n","Creator.Formular = {};\n\nCreator.Formular.PREFIX = \"_VALUES\";\n\nCreator.Formular._prependPrefixForFormula = function(prefix, fieldVariable) {\n var reg, rev;\n reg = /(\\{[^{}]*\\})/g;\n rev = fieldVariable.replace(reg, function(m, $1) {\n return prefix + $1.replace(/\\{\\s*/, \"[\\\"\").replace(/\\s*\\}/, \"\\\"]\").replace(/\\s*\\.\\s*/g, \"\\\"][\\\"\");\n });\n return rev;\n};\n\nCreator.Formular.checkFormula = function(formula_str) {\n if (_.isString(formula_str) && formula_str.indexOf(\"{\") > -1 && formula_str.indexOf(\"}\") > -1) {\n return true;\n }\n return false;\n};\n\nCreator.Formular.run = function(formula_str, _CONTEXT, options) {\n var _VALUES, data, e, extend;\n if (formula_str && _.isString(formula_str)) {\n if (!_.isBoolean(options != null ? options.extend : void 0)) {\n extend = true;\n }\n _VALUES = {};\n _VALUES = _.extend(_VALUES, _CONTEXT);\n if (extend) {\n _VALUES = _.extend(_VALUES, Creator.getUserContext(options != null ? options.userId : void 0, options != null ? options.spaceId : void 0));\n }\n formula_str = Creator.Formular._prependPrefixForFormula(\"this\", formula_str);\n try {\n data = Creator.evalInContext(formula_str, _VALUES);\n return data;\n } catch (error) {\n e = error;\n console.error(\"Creator.Formular.run: \" + formula_str, e);\n if (Meteor.isClient) {\n if (typeof toastr !== \"undefined\" && toastr !== null) {\n toastr.error(\"公式执行出错了,请检查公式配置是否正确!\");\n }\n }\n throw new Meteor.Error(500, \"Creator.Formular.run: \" + formula_str + e);\n }\n }\n return formula_str;\n};\n","clone = require('clone');\nCreator.objectsByName = {} # 此对象只能在确保所有Object初始化完成后调用, 否则获取到的object不全\n\nCreator.formatObjectName = (object_name)->\n\tif object_name.startsWith('cfs.files.')\n\t\tobject_name = object_name.replace(new RegExp('\\\\.', 'g'), '_')\n\treturn object_name\n\nCreator.Object = (options)->\n\t_baseObject = Creator.baseObject\n\tif Meteor.isClient\n\t\t_baseObject = {actions: Creator.baseObject.actions , fields: {}, triggers: {}, permission_set: {}}\n\tself = this\n\tif (!options.name)\n\t\tconsole.error(options)\n\t\tthrow new Error('Creator.Object options must specify name');\n\n\tself._id = options._id || options.name\n\tself.space = options.space\n\tself.name = options.name\n\tself.label = options.label\n\tself.icon = options.icon\n\tself.description = options.description\n\tself.is_view = options.is_view\n\tself.form = options.form\n\tself.relatedList = options.relatedList\n\tself.related_lists = options.related_lists\n\tself.hasImportTemplates = options.hasImportTemplates\n\tself.version = options.version || 1.0\n\tif !_.isBoolean(options.is_enable) || options.is_enable == true\n\t\tself.is_enable = true\n\telse\n\t\tself.is_enable = false\n\tif Meteor.isClient\n\t\tif _.has(options, 'allow_customActions')\n\t\t\tself.allow_customActions = options.allow_customActions\n\t\tif _.has(options, 'exclude_actions')\n\t\t\tself.exclude_actions = options.exclude_actions\n\t\tif _.has(options, 'allow_relatedList')\n\t\t\tself.allow_relatedList = options.allow_relatedList\n\tself.enable_search = options.enable_search\n\tself.enable_files = options.enable_files\n\tself.enable_tasks = options.enable_tasks\n\tself.enable_notes = options.enable_notes\n\tself.enable_audit = options.enable_audit\n\tself.enable_events = options.enable_events\n\tif options.paging\n\t\tself.paging = options.paging\n\tself.hidden = options.hidden\n\tself.enable_api = (options.enable_api == undefined) or options.enable_api\n\tself.custom = options.custom\n\tself.enable_share = options.enable_share\n\tself.enable_instances = options.enable_instances\n\tself.enable_process = options.enable_process\n\tif Meteor.isClient\n\t\tif Creator.isCloudAdminSpace(Session.get(\"spaceId\"))\n\t\t\tself.enable_tree = false\n\t\telse\n\t\t\tself.enable_tree = options.enable_tree\n\t\t\tself.sidebar = _.clone(options.sidebar)\n\telse\n\t\tself.sidebar = _.clone(options.sidebar)\n\t\tself.enable_tree = options.enable_tree\n\tself.open_window = options.open_window\n\tself.filter_company = options.filter_company\n\tself.calendar = _.clone(options.calendar)\n\tself.enable_chatter = options.enable_chatter\n\tself.enable_trash = options.enable_trash\n\tself.enable_space_global = options.enable_space_global\n\tself.enable_approvals = options.enable_approvals\n\tself.enable_follow = options.enable_follow\n\tself.enable_workflow = options.enable_workflow\n\tself.enable_inline_edit = options.enable_inline_edit\n\tself.details = options.details\n\tself.masters = options.masters\n\tself.lookup_details = options.lookup_details\n\tif _.has(options, 'in_development')\n\t\tself.in_development = options.in_development\n\tself.idFieldName = '_id'\n\tif options.database_name\n\t\tself.database_name = options.database_name\n\tif (!options.fields)\n\t\tconsole.error(options)\n\t\tthrow new Error('Creator.Object options must specify fields');\n\n\tself.fields = clone(options.fields)\n\n\t_.each self.fields, (field, field_name)->\n\t\tif field.is_name\n\t\t\tself.NAME_FIELD_KEY = field_name\n\t\telse if field_name == 'name' && !self.NAME_FIELD_KEY\n\t\t\tself.NAME_FIELD_KEY = field_name\n\t\tif field.primary\n\t\t\tself.idFieldName = field_name\n\t\tif Meteor.isClient\n\t\t\tif Creator.isCloudAdminSpace(Session.get(\"spaceId\"))\n\t\t\t\tif field_name == 'space'\n\t\t\t\t\tfield.filterable = true\n\t\t\t\t\tfield.hidden = false\n\n\tif !options.database_name || options.database_name == 'meteor-mongo'\n\t\t_.each _baseObject.fields, (field, field_name)->\n\t\t\tif !self.fields[field_name]\n\t\t\t\tself.fields[field_name] = {}\n\t\t\tself.fields[field_name] = _.extend(_.clone(field), self.fields[field_name])\n\n\t_.each self.fields, (field, field_name)->\n\t\tif field.type == 'autonumber'\n\t\t\tfield.readonly = true\n\t\telse if field.type == 'formula'\n\t\t\tfield.readonly = true\n\t\telse if field.type == 'summary'\n\t\t\tfield.readonly = true\n\n\tself.list_views = {}\n\tdefaultView = Creator.getObjectDefaultView(self.name)\n\t_.each options.list_views, (item, item_name)->\n\t\toitem = Creator.convertListView(defaultView, item, item_name)\n\t\tself.list_views[item_name] = oitem\n\n\tself.triggers = _.clone(_baseObject.triggers)\n\t_.each options.triggers, (item, item_name)->\n\t\tif !self.triggers[item_name]\n\t\t\tself.triggers[item_name] = {}\n\t\tself.triggers[item_name].name = item_name\n\t\tself.triggers[item_name] = _.extend(_.clone(self.triggers[item_name]), item)\n\n\tself.actions = _.clone(_baseObject.actions)\n\t_.each options.actions, (item, item_name)->\n\t\tif !self.actions[item_name]\n\t\t\tself.actions[item_name] = {}\n\t\tcopyItem = _.clone(self.actions[item_name])\n\t\tdelete self.actions[item_name] #先删除相关属性再重建才能保证后续重复定义的属性顺序生效\n\t\tself.actions[item_name] = _.extend(copyItem, item)\n\t\tself.actions[item_name].object_name = self.name\n\n\t_.each self.actions, (item, item_name)->\n\t\titem.name = item_name\n\n\tself.related_objects = Creator.getObjectRelateds(self.name)\n\n\t# 让所有object默认有所有list_views/actions/related_objects/readable_fields/editable_fields完整权限,该权限可能被数据库中设置的admin/user权限覆盖\n\tself.permission_set = _.clone(_baseObject.permission_set)\n\t# defaultListViews = _.keys(self.list_views)\n\t# defaultActions = _.keys(self.actions)\n\t# defaultRelatedObjects = _.pluck(self.related_objects,\"object_name\")\n\t# defaultReadableFields = []\n\t# defaultEditableFields = []\n\t# _.each self.fields, (field, field_name)->\n\t# \tif !(field.hidden) #231 omit字段支持在非编辑页面查看, 因此删除了此处对omit的判断\n\t# \t\tdefaultReadableFields.push field_name\n\t# \t\tif !field.readonly\n\t# \t\t\tdefaultEditableFields.push field_name\n\n\t# _.each self.permission_set, (item, item_name)->\n\t# \tif item_name == \"none\"\n\t# \t\treturn\n\t# \tif self.list_views\n\t# \t\tself.permission_set[item_name].list_views = defaultListViews\n\t# \tif self.actions\n\t# \t\tself.permission_set[item_name].actions = defaultActions\n\t# \tif self.related_objects\n\t# \t\tself.permission_set[item_name].related_objects = defaultRelatedObjects\n\t# \tif self.fields\n\t# \t\tself.permission_set[item_name].readable_fields = defaultReadableFields\n\t# \t\tself.permission_set[item_name].editable_fields = defaultEditableFields\n\tunless options.permission_set\n\t\toptions.permission_set = {}\n\tif !(options.permission_set?.admin)\n\t\toptions.permission_set.admin = _.clone(self.permission_set[\"admin\"])\n\tif !(options.permission_set?.user)\n\t\toptions.permission_set.user = _.clone(self.permission_set[\"user\"])\n\t_.each options.permission_set, (item, item_name)->\n\t\tif !self.permission_set[item_name]\n\t\t\tself.permission_set[item_name] = {}\n\t\tself.permission_set[item_name] = _.extend(_.clone(self.permission_set[item_name]), item)\n\n\t# 前端根据permissions改写field相关属性,后端只要走默认属性就行,不需要改写\n\tif Meteor.isClient\n\t\tpermissions = options.permissions\n\t\tdisabled_list_views = permissions?.disabled_list_views\n\t\tif disabled_list_views?.length\n\t\t\tdefaultListViewId = options.list_views?.all?._id\n\t\t\tif defaultListViewId\n\t\t\t\t# 把视图权限配置中默认的all视图id转换成all关键字\n\t\t\t\tpermissions.disabled_list_views = _.map disabled_list_views, (list_view_item) ->\n\t\t\t\t\treturn if defaultListViewId == list_view_item then \"all\" else list_view_item\n\t\tself.permissions = new ReactiveVar(permissions)\n#\t\t_.each self.fields, (field, field_name)->\n#\t\t\tif field\n#\t\t\t\tif _.indexOf(permissions?.unreadable_fields, field_name) < 0\n#\t\t\t\t\tif field.hidden\n#\t\t\t\t\t\treturn\n#\t\t\t\t\tif _.indexOf(permissions?.uneditable_fields, field_name) > -1\n#\t\t\t\t\t\tfield.readonly = true\n#\t\t\t\t\t\tfield.disabled = true\n#\t\t\t\t\t\t# 当只读时,如果不去掉必填字段,autoform是会报错的\n#\t\t\t\t\t\tfield.required = false\n#\t\t\t\telse\n#\t\t\t\t\tfield.hidden = true\n\telse\n\t\tself.permissions = null\n\n\t_db = Creator.createCollection(options)\n\n\tCreator.Collections[_db._name] = _db\n\n\tself.db = _db\n\n\tself._collection_name = _db._name\n\n\tschema = Creator.getObjectSchema(self)\n\tself.schema = new SimpleSchema(schema)\n\tif self.name != \"users\" and self.name != \"cfs.files.filerecord\" && !self.is_view && !_.contains([\"flows\", \"forms\", \"instances\", \"organizations\", \"action_field_updates\", \"object_listviews\"], self.name)\n\t\tif Meteor.isClient\n\t\t\t_db.attachSchema(self.schema, {replace: true})\n\t\telse\n\t\t\t_db.attachSchema(self.schema, {replace: true})\n\tif self.name == \"users\"\n\t\t_db._simpleSchema = self.schema\n\n\tif _.contains([\"flows\", \"forms\", \"instances\", \"organizations\"], self.name)\n\t\tif Meteor.isClient\n\t\t\t_db.attachSchema(self.schema, {replace: true})\n\n\tCreator.objectsByName[self._collection_name] = self\n\n\treturn self\n\n# Creator.Object.prototype.i18n = ()->\n# \t# set object label\n# \tself = this\n\n# \tkey = self.name\n# \tif t(key) == key\n# \t\tif !self.label\n# \t\t\tself.label = self.name\n# \telse\n# \t\tself.label = t(key)\n\n# \t# set field labels\n# \t_.each self.fields, (field, field_name)->\n# \t\tfkey = self.name + \"_\" + field_name\n# \t\tif t(fkey) == fkey\n# \t\t\tif !field.label\n# \t\t\t\tfield.label = field_name\n# \t\telse\n# \t\t\tfield.label = t(fkey)\n# \t\tself.schema?._schema?[field_name]?.label = field.label\n\n\n# \t# set listview labels\n# \t_.each self.list_views, (item, item_name)->\n# \t\ti18n_key = self.name + \"_listview_\" + item_name\n# \t\tif t(i18n_key) == i18n_key\n# \t\t\tif !item.label\n# \t\t\t\titem.label = item_name\n# \t\telse\n# \t\t\titem.label = t(i18n_key)\n\n\nCreator.getObjectODataRouterPrefix = (object)->\n\treturn \"/api/odata/v4\"\n\t# if object\n\t# \tif !object.database_name || object.database_name == 'meteor-mongo'\n\t# \t\treturn \"/api/odata/v4\"\n\t# \telse\n\t# \t\treturn \"/api/odata/#{object.database_name}\"\n\n# if Meteor.isClient\n\n# \tMeteor.startup ->\n# \t\tTracker.autorun ->\n# \t\t\tif Session.get(\"steedos-locale\") && Creator.bootstrapLoaded?.get()\n# \t\t\t\t_.each Creator.objectsByName, (object, object_name)->\n# \t\t\t\t\tobject.i18n()\n\nMeteor.startup ->\n\tif !Creator.bootstrapLoaded && Creator.Objects\n\t\t_.each Creator.Objects, (object)->\n\t\t\tnew Creator.Object(object)\n\n","var clone;\n\nclone = require('clone');\n\nCreator.objectsByName = {};\n\nCreator.formatObjectName = function(object_name) {\n if (object_name.startsWith('cfs.files.')) {\n object_name = object_name.replace(new RegExp('\\\\.', 'g'), '_');\n }\n return object_name;\n};\n\nCreator.Object = function(options) {\n var _baseObject, _db, defaultListViewId, defaultView, disabled_list_views, permissions, ref, ref1, ref2, ref3, schema, self;\n _baseObject = Creator.baseObject;\n if (Meteor.isClient) {\n _baseObject = {\n actions: Creator.baseObject.actions,\n fields: {},\n triggers: {},\n permission_set: {}\n };\n }\n self = this;\n if (!options.name) {\n console.error(options);\n throw new Error('Creator.Object options must specify name');\n }\n self._id = options._id || options.name;\n self.space = options.space;\n self.name = options.name;\n self.label = options.label;\n self.icon = options.icon;\n self.description = options.description;\n self.is_view = options.is_view;\n self.form = options.form;\n self.relatedList = options.relatedList;\n self.related_lists = options.related_lists;\n self.hasImportTemplates = options.hasImportTemplates;\n self.version = options.version || 1.0;\n if (!_.isBoolean(options.is_enable) || options.is_enable === true) {\n self.is_enable = true;\n } else {\n self.is_enable = false;\n }\n if (Meteor.isClient) {\n if (_.has(options, 'allow_customActions')) {\n self.allow_customActions = options.allow_customActions;\n }\n if (_.has(options, 'exclude_actions')) {\n self.exclude_actions = options.exclude_actions;\n }\n if (_.has(options, 'allow_relatedList')) {\n self.allow_relatedList = options.allow_relatedList;\n }\n }\n self.enable_search = options.enable_search;\n self.enable_files = options.enable_files;\n self.enable_tasks = options.enable_tasks;\n self.enable_notes = options.enable_notes;\n self.enable_audit = options.enable_audit;\n self.enable_events = options.enable_events;\n if (options.paging) {\n self.paging = options.paging;\n }\n self.hidden = options.hidden;\n self.enable_api = (options.enable_api === void 0) || options.enable_api;\n self.custom = options.custom;\n self.enable_share = options.enable_share;\n self.enable_instances = options.enable_instances;\n self.enable_process = options.enable_process;\n if (Meteor.isClient) {\n if (Creator.isCloudAdminSpace(Session.get(\"spaceId\"))) {\n self.enable_tree = false;\n } else {\n self.enable_tree = options.enable_tree;\n self.sidebar = _.clone(options.sidebar);\n }\n } else {\n self.sidebar = _.clone(options.sidebar);\n self.enable_tree = options.enable_tree;\n }\n self.open_window = options.open_window;\n self.filter_company = options.filter_company;\n self.calendar = _.clone(options.calendar);\n self.enable_chatter = options.enable_chatter;\n self.enable_trash = options.enable_trash;\n self.enable_space_global = options.enable_space_global;\n self.enable_approvals = options.enable_approvals;\n self.enable_follow = options.enable_follow;\n self.enable_workflow = options.enable_workflow;\n self.enable_inline_edit = options.enable_inline_edit;\n self.details = options.details;\n self.masters = options.masters;\n self.lookup_details = options.lookup_details;\n if (_.has(options, 'in_development')) {\n self.in_development = options.in_development;\n }\n self.idFieldName = '_id';\n if (options.database_name) {\n self.database_name = options.database_name;\n }\n if (!options.fields) {\n console.error(options);\n throw new Error('Creator.Object options must specify fields');\n }\n self.fields = clone(options.fields);\n _.each(self.fields, function(field, field_name) {\n if (field.is_name) {\n self.NAME_FIELD_KEY = field_name;\n } else if (field_name === 'name' && !self.NAME_FIELD_KEY) {\n self.NAME_FIELD_KEY = field_name;\n }\n if (field.primary) {\n self.idFieldName = field_name;\n }\n if (Meteor.isClient) {\n if (Creator.isCloudAdminSpace(Session.get(\"spaceId\"))) {\n if (field_name === 'space') {\n field.filterable = true;\n return field.hidden = false;\n }\n }\n }\n });\n if (!options.database_name || options.database_name === 'meteor-mongo') {\n _.each(_baseObject.fields, function(field, field_name) {\n if (!self.fields[field_name]) {\n self.fields[field_name] = {};\n }\n return self.fields[field_name] = _.extend(_.clone(field), self.fields[field_name]);\n });\n }\n _.each(self.fields, function(field, field_name) {\n if (field.type === 'autonumber') {\n return field.readonly = true;\n } else if (field.type === 'formula') {\n return field.readonly = true;\n } else if (field.type === 'summary') {\n return field.readonly = true;\n }\n });\n self.list_views = {};\n defaultView = Creator.getObjectDefaultView(self.name);\n _.each(options.list_views, function(item, item_name) {\n var oitem;\n oitem = Creator.convertListView(defaultView, item, item_name);\n return self.list_views[item_name] = oitem;\n });\n self.triggers = _.clone(_baseObject.triggers);\n _.each(options.triggers, function(item, item_name) {\n if (!self.triggers[item_name]) {\n self.triggers[item_name] = {};\n }\n self.triggers[item_name].name = item_name;\n return self.triggers[item_name] = _.extend(_.clone(self.triggers[item_name]), item);\n });\n self.actions = _.clone(_baseObject.actions);\n _.each(options.actions, function(item, item_name) {\n var copyItem;\n if (!self.actions[item_name]) {\n self.actions[item_name] = {};\n }\n copyItem = _.clone(self.actions[item_name]);\n delete self.actions[item_name];\n self.actions[item_name] = _.extend(copyItem, item);\n return self.actions[item_name].object_name = self.name;\n });\n _.each(self.actions, function(item, item_name) {\n return item.name = item_name;\n });\n self.related_objects = Creator.getObjectRelateds(self.name);\n self.permission_set = _.clone(_baseObject.permission_set);\n if (!options.permission_set) {\n options.permission_set = {};\n }\n if (!((ref = options.permission_set) != null ? ref.admin : void 0)) {\n options.permission_set.admin = _.clone(self.permission_set[\"admin\"]);\n }\n if (!((ref1 = options.permission_set) != null ? ref1.user : void 0)) {\n options.permission_set.user = _.clone(self.permission_set[\"user\"]);\n }\n _.each(options.permission_set, function(item, item_name) {\n if (!self.permission_set[item_name]) {\n self.permission_set[item_name] = {};\n }\n return self.permission_set[item_name] = _.extend(_.clone(self.permission_set[item_name]), item);\n });\n if (Meteor.isClient) {\n permissions = options.permissions;\n disabled_list_views = permissions != null ? permissions.disabled_list_views : void 0;\n if (disabled_list_views != null ? disabled_list_views.length : void 0) {\n defaultListViewId = (ref2 = options.list_views) != null ? (ref3 = ref2.all) != null ? ref3._id : void 0 : void 0;\n if (defaultListViewId) {\n permissions.disabled_list_views = _.map(disabled_list_views, function(list_view_item) {\n if (defaultListViewId === list_view_item) {\n return \"all\";\n } else {\n return list_view_item;\n }\n });\n }\n }\n self.permissions = new ReactiveVar(permissions);\n } else {\n self.permissions = null;\n }\n _db = Creator.createCollection(options);\n Creator.Collections[_db._name] = _db;\n self.db = _db;\n self._collection_name = _db._name;\n schema = Creator.getObjectSchema(self);\n self.schema = new SimpleSchema(schema);\n if (self.name !== \"users\" && self.name !== \"cfs.files.filerecord\" && !self.is_view && !_.contains([\"flows\", \"forms\", \"instances\", \"organizations\", \"action_field_updates\", \"object_listviews\"], self.name)) {\n if (Meteor.isClient) {\n _db.attachSchema(self.schema, {\n replace: true\n });\n } else {\n _db.attachSchema(self.schema, {\n replace: true\n });\n }\n }\n if (self.name === \"users\") {\n _db._simpleSchema = self.schema;\n }\n if (_.contains([\"flows\", \"forms\", \"instances\", \"organizations\"], self.name)) {\n if (Meteor.isClient) {\n _db.attachSchema(self.schema, {\n replace: true\n });\n }\n }\n Creator.objectsByName[self._collection_name] = self;\n return self;\n};\n\nCreator.getObjectODataRouterPrefix = function(object) {\n return \"/api/odata/v4\";\n};\n\nMeteor.startup(function() {\n if (!Creator.bootstrapLoaded && Creator.Objects) {\n return _.each(Creator.Objects, function(object) {\n return new Creator.Object(object);\n });\n }\n});\n","Creator.getSelectOptions = (fieldSchema) ->\n\toptions = fieldSchema.options\n\tunless options\n\t\treturn\n\tdata_type = fieldSchema.data_type\n\tif !_.isFunction(options) and data_type and data_type != 'text'\n\t\t# 零代码界面配置options选项值只支持字符串,所以当data_type为数值或boolean时,只能强行把选项值先转换为对应的类型\n\t\toptions.forEach (optionItem) ->\n\t\t\tif typeof optionItem.value != 'string'\n\t\t\t\treturn\n\t\t\tif [\n\t\t\t\t'number'\n\t\t\t\t'currency'\n\t\t\t\t'percent'\n\t\t\t].indexOf(data_type) > -1\n\t\t\t\toptionItem.value = Number(optionItem.value)\n\t\t\telse if data_type == 'boolean'\n\t\t\t\t# 只有为true才为真\n\t\t\t\toptionItem.value = optionItem.value == 'true'\n\treturn options\n\nCreator.getObjectSchema = (obj) ->\n\tunless obj\n\t\treturn\n\tschema = {}\n\n\tfieldsArr = []\n\n\t_.each obj.fields , (field, field_name)->\n\t\tif !_.has(field, \"name\")\n\t\t\tfield.name = field_name\n\t\tfieldsArr.push field\n\n\t_.each _.sortBy(fieldsArr, \"sort_no\"), (field)->\n\n\t\tfield_name = field.name\n\n\t\tfs = {}\n\t\tif field.regEx\n\t\t\tfs.regEx = field.regEx\n\t\tfs.autoform = {}\n\t\tfs.autoform.multiple = field.multiple\n\t\tfs.autoform.reference_to = field.reference_to\n\n\t\tautoform_type = field.autoform?.type\n\n\t\tif field.type == \"text\" or field.type == \"phone\"\n\t\t\tfs.type = String\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tfs.autoform.type = \"tags\"\n\t\telse if field.type == \"[text]\" or field.type == \"[phone]\"\n\t\t\tfs.type = [String]\n\t\t\tfs.autoform.type = \"tags\"\n\t\telse if field.type == 'code'\n\t\t\tfs.type = String\n\t\t\tfs.autoform.type = \"widearea\"\n\t\t\tfs.autoform.rows = field.rows || 12\n\t\t\tif field.language\n\t\t\t\tfs.autoform.language = field.language\n\t\telse if field.type == \"textarea\"\n\t\t\tfs.type = String\n\t\t\tfs.autoform.type = \"widearea\"\n\t\t\tfs.autoform.rows = field.rows || 2\n\t\telse if field.type == \"password\"\n\t\t\tfs.type = String\n\t\t\tfs.autoform.type = \"password\"\n\t\telse if field.type == \"date\"\n\t\t\tfs.type = Date\n\t\t\tif Meteor.isClient\n\t\t\t\tif Steedos.isMobile() || Steedos.isPad()\n\t\t\t\t\tif Steedos.isiOS()\n\t\t\t\t\t\t# Fix ios 14, 手机客户端待审核文件日期控件显示故障 #991,ios统一用PC端一样的js控件\n\t\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\t\t\ttimezoneId: \"utc\"\n\t\t\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\t\t\ttype: \"date\"\n\t\t\t\t\t\t\t\tdisplayFormat: \"yyyy-MM-dd\"\n\t\t\t\t\t\t\t\tpickerType: \"rollers\"\n\t\t\t\t\telse\n\t\t\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\t\ttype: \"steedos-date-mobile\"\n\t\t\t\t\t\t\tdateMobileOptions:\n\t\t\t\t\t\t\t\ttype: \"date\"\n\t\t\t\telse\n\t\t\t\t\tfs.autoform.outFormat = 'yyyy-MM-dd';\n\t\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\t\ttimezoneId: \"utc\"\n\t\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\t\ttype: \"date\"\n\t\t\t\t\t\t\tdisplayFormat: \"yyyy-MM-dd\"\n\t\telse if field.type == \"time\"\n\t\t\tfs.type = Date\n\t\t\tif Meteor.isClient\n\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\ttimezoneId: \"utc\"\n\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\ttype: \"time\"\n\t\t\t\t\t\tdisplayFormat: \"HH:mm\"\n\t\telse if field.type == \"datetime\"\n\t\t\tfs.type = Date\n\t\t\tif Meteor.isClient\n\t\t\t\tif Steedos.isMobile() || Steedos.isPad()\n\t\t\t\t\tif Steedos.isiOS()\n\t\t\t\t\t\t# Fix ios 14, 手机客户端待审核文件日期控件显示故障 #991,ios统一用PC端一样的js控件\n\t\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\t\t\ttype: \"datetime\"\n\t\t\t\t\t\t\t\tdisplayFormat: \"yyyy-MM-dd HH:mm\"\n\t\t\t\t\t\t\t\tpickerType: \"rollers\"\n\t\t\t\t\telse\n\t\t\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\t\ttype: \"steedos-date-mobile\"\n\t\t\t\t\t\t\tdateMobileOptions:\n\t\t\t\t\t\t\t\ttype: \"datetime\"\n\t\t\t\telse\n\t\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\t\ttype: \"datetime\"\n\t\t\t\t\t\t\tdisplayFormat: \"yyyy-MM-dd HH:mm\"\n\t\telse if field.type == \"[Object]\"\n\t\t\tfs.type = [Object]\n\t\telse if field.type == \"html\"\n\t\t\tfs.type = String\n\t\t\tif Meteor.isClient\n\t\t\t\tfs.autoform.type = 'steedosHtml';\n\t\t\t# if Meteor.isClient\n\t\t\t# \tlocale = Steedos.locale()\n\t\t\t# \tif locale == \"zh-cn\" || locale == \"zh-CN\"\n\t\t\t# \t\tlocale = \"zh-CN\"\n\t\t\t# \telse\n\t\t\t# \t\tlocale = \"en-US\"\n\t\t\t# \tfs.autoform.afFieldInput =\n\t\t\t# \t\ttype: \"summernote\"\n\t\t\t# \t\tclass: 'summernote-editor'\n\t\t\t# \t\tsettings:\n\t\t\t# \t\t\theight: 200\n\t\t\t# \t\t\tdialogsInBody: true\n\t\t\t# \t\t\ttoolbar: [\n\t\t\t# \t\t\t\t['font1', ['style']],\n\t\t\t# \t\t\t\t['font2', ['bold', 'underline', 'italic', 'clear']],\n\t\t\t# \t\t\t\t['font3', ['fontname']],\n\t\t\t# \t\t\t\t['color', ['color']],\n\t\t\t# \t\t\t\t['para', ['ul', 'ol', 'paragraph']],\n\t\t\t# \t\t\t\t['table', ['table']],\n\t\t\t# \t\t\t\t['insert', ['link', 'picture']],\n\t\t\t# \t\t\t\t['view', ['codeview']]\n\t\t\t# \t\t\t]\n\t\t\t# \t\t\tfontNames: ['Arial', 'Comic Sans MS', 'Courier New', 'Helvetica', 'Impact', '宋体','黑体','微软雅黑','仿宋','楷体','隶书','幼圆']\n\t\t\t# \t\t\tlang: locale\n\n\t\telse if (field.type == \"lookup\" or field.type == \"master_detail\")\n\t\t\tfs.type = String\n\t\t\tfs.autoform.showIcon = field.showIcon\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\n\t\t\tif !field.hidden\n\n\t\t\t\tfs.autoform.filters = field.filters\n\n\t\t\t\tfs.autoform.dependOn = field.depend_on\n\n\t\t\t\tif field.beforeOpenFunction\n\t\t\t\t\tfs.beforeOpenFunction = field.beforeOpenFunction\n\n\t\t\t\tfs.filtersFunction = if field.filtersFunction then field.filtersFunction else Creator.evaluateFilters\n\n\t\t\t\tif field.optionsFunction\n\t\t\t\t\tfs.optionsFunction = field.optionsFunction\n\n\t\t\t\tif field.reference_to\n\n\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\tif field.createFunction && _.isFunction(field.createFunction)\n\t\t\t\t\t\t\tfs.createFunction = field.createFunction\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tif _.isString(field.reference_to)\n\t\t\t\t\t\t\t\t_ref_obj = Creator.Objects[field.reference_to]\n\t\t\t\t\t\t\t\tif _ref_obj?.permissions?.allowCreate\n\t\t\t\t\t\t\t\t\tfs.autoform.create = true\n\t\t\t\t\t\t\t\t\tfs.createFunction = (lookup_field)->\n\t\t\t\t\t\t\t\t\t\tModal.show(\"CreatorObjectModal\", {\n\t\t\t\t\t\t\t\t\t\t\tcollection: \"Creator.Collections.#{Creator.getCollection(field.reference_to)._name}\",\n\t\t\t\t\t\t\t\t\t\t\tformId: \"new#{field.reference_to.replace('.','_')}\",\n\t\t\t\t\t\t\t\t\t\t\tobject_name: \"#{field.reference_to}\",\n\t\t\t\t\t\t\t\t\t\t\toperation: \"insert\",\n\t\t\t\t\t\t\t\t\t\t\tonSuccess: (operation, result)->\n\t\t\t\t\t\t\t\t\t\t\t\tobject = Creator.getObject(result.object_name)\n\t\t\t\t\t\t\t\t\t\t\t\tif result.object_name == \"objects\"\n\t\t\t\t\t\t\t\t\t\t\t\t\tlookup_field.addItems([{label: result.value.label, value: result.value.name, icon: result.value.icon}], result.value.name)\n\t\t\t\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\t\t\t\tlookup_field.addItems([{label: result.value[object.NAME_FIELD_KEY] || result.value.label || result.value.name, value: result._id}], result._id)\n\t\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\tfs.autoform.create = false\n\n\t\t\t\t\tif _.isBoolean(field.create)\n\t\t\t\t\t\tfs.autoform.create = field.create\n\n\t\t\t\t\tif field.reference_sort\n\t\t\t\t\t\tfs.autoform.optionsSort = field.reference_sort\n\n\t\t\t\t\tif field.reference_limit\n\t\t\t\t\t\tfs.autoform.optionsLimit = field.reference_limit\n\t\t\t\t\tif field.reference_to_field\n\t\t\t\t\t\tfs.autoform.referenceToField = field.reference_to_field\n\n\t\t\t\t\tif field.reference_to == \"users\"\n\t\t\t\t\t\tfs.autoform.type = \"selectuser\"\n\t\t\t\t\t\tif !field.hidden && !field.omit\n\t\t\t\t\t\t\t# is_company_limited表示过滤数据时是否只显示本分部下的数据\n\t\t\t\t\t\t\t# is_company_limited可以被改写覆盖成true/false或其他function\n\t\t\t\t\t\t\tif field.is_company_limited == undefined\n\t\t\t\t\t\t\t\t# 未定义is_company_limited属性时默认处理逻辑:\n\t\t\t\t\t\t\t\t# 对当前对象有viewAllRecords权限则不限制所属分部列表查看权限,否则只显示当前所属分部\n\t\t\t\t\t\t\t\t# 注意不是reference_to对象的viewAllRecords权限,而是当前对象的\n\t\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\t\tpermissions = obj.permissions\n\t\t\t\t\t\t\t\t\tisUnLimited = permissions?.viewAllRecords\n\t\t\t\t\t\t\t\t\tif _.include([\"organizations\", \"users\", \"space_users\"], obj.name)\n\t\t\t\t\t\t\t\t\t\t# 如果字段所属对象是用户或组织,则是否限制显示所属分部部门与modifyAllRecords权限关联\n\t\t\t\t\t\t\t\t\t\tisUnLimited = permissions?.modifyAllRecords\n\t\t\t\t\t\t\t\t\tif isUnLimited\n\t\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = false\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = true\n\t\t\t\t\t\t\telse if _.isFunction field.is_company_limited\n\t\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\t\t# 传入当前对象的权限,在函数中根据权限计算是否要限制只查看本分部\n\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited(obj.permissions)\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t# 服务端用不到is_company_limited\n\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = true\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited\n\t\t\t\t\telse if field.reference_to == \"organizations\"\n\t\t\t\t\t\tfs.autoform.type = \"selectorg\"\n\t\t\t\t\t\tif !field.hidden && !field.omit\n\t\t\t\t\t\t\t# is_company_limited表示过滤数据时是否只显示本分部下的数据\n\t\t\t\t\t\t\t# is_company_limited可以被改写覆盖成true/false或其他function\n\t\t\t\t\t\t\tif field.is_company_limited == undefined\n\t\t\t\t\t\t\t\t# 未定义is_company_limited属性时默认处理逻辑:\n\t\t\t\t\t\t\t\t# 对当前对象有viewAllRecords权限则不限制所属分部列表查看权限,否则只显示当前所属分部\n\t\t\t\t\t\t\t\t# 注意不是reference_to对象的viewAllRecords权限,而是当前对象的\n\t\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\t\tpermissions = obj.permissions\n\t\t\t\t\t\t\t\t\tisUnLimited = permissions?.viewAllRecords\n\t\t\t\t\t\t\t\t\tif _.include([\"organizations\", \"users\", \"space_users\"], obj.name)\n\t\t\t\t\t\t\t\t\t\t# 如果字段所属对象是用户或组织,则是否限制显示所属分部部门与modifyAllRecords权限关联\n\t\t\t\t\t\t\t\t\t\tisUnLimited = permissions?.modifyAllRecords\n\t\t\t\t\t\t\t\t\tif isUnLimited\n\t\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = false\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = true\n\t\t\t\t\t\t\telse if _.isFunction field.is_company_limited\n\t\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\t\t# 传入当前对象的权限,在函数中根据权限计算是否要限制只查看本分部\n\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited(obj.permissions)\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t# 服务端用不到is_company_limited\n\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = true\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited\n\t\t\t\t\telse\n\t\t\t\t\t\tif typeof(field.reference_to) == \"function\"\n\t\t\t\t\t\t\t_reference_to = field.reference_to()\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t_reference_to = field.reference_to\n\n\t\t\t\t\t\tif _.isArray(_reference_to)\n\t\t\t\t\t\t\tfs.type = Object\n\t\t\t\t\t\t\tfs.blackbox = true\n\t\t\t\t\t\t\tfs.autoform.objectSwitche = true\n\n\t\t\t\t\t\t\tschema[field_name + \".o\"] = {\n\t\t\t\t\t\t\t\ttype: String\n\t\t\t\t\t\t\t\tautoform: {omit: true}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tschema[field_name + \".ids\"] = {\n\t\t\t\t\t\t\t\ttype: [String]\n\t\t\t\t\t\t\t\tautoform: {omit: true}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t_reference_to = [_reference_to]\n\n\t\t\t\t\t\t_object = Creator.Objects[_reference_to[0]]\n\t\t\t\t\t\tif _object and _object.enable_tree\n\t\t\t\t\t\t\tfs.autoform.type = \"selectTree\"\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tfs.autoform.type = \"steedosLookups\"\n\t\t\t\t\t\t\tfs.autoform.optionsMethod = field.optionsMethod || \"creator.object_options\"\n\n\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\tfs.autoform.optionsMethodParams = ()->\n\t\t\t\t\t\t\t\t\treturn {space: Session.get(\"spaceId\")}\n\t\t\t\t\t\t\t\tfs.autoform.references = []\n\t\t\t\t\t\t\t\t_reference_to.forEach (_reference)->\n\t\t\t\t\t\t\t\t\t_object = Creator.Objects[_reference]\n\t\t\t\t\t\t\t\t\tif _object\n\t\t\t\t\t\t\t\t\t\tfs.autoform.references.push {\n\t\t\t\t\t\t\t\t\t\t\tobject: _reference\n\t\t\t\t\t\t\t\t\t\t\tlabel: _object?.label\n\t\t\t\t\t\t\t\t\t\t\ticon: _object?.icon\n\t\t\t\t\t\t\t\t\t\t\tlink: ()->\n\t\t\t\t\t\t\t\t\t\t\t\treturn \"/app/#{Session.get('app_id')}/#{_reference}/view/\"\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tfs.autoform.references.push {\n\t\t\t\t\t\t\t\t\t\t\tobject: _reference\n\t\t\t\t\t\t\t\t\t\t\tlink: ()->\n\t\t\t\t\t\t\t\t\t\t\t\treturn \"/app/#{Session.get('app_id')}/#{_reference}/view/\"\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\telse\n\t\t\t\t\tfs.autoform.type = \"steedosLookups\"\n\t\t\t\t\tfs.autoform.defaultIcon = field.defaultIcon\n\n\t\telse if field.type == \"select\"\n\t\t\tfs.type = String\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tfs.autoform.type = \"steedosLookups\"\n\t\t\t\tfs.autoform.showIcon = false\n\t\t\t\tfs.autoform.options = field.options\n\t\t\telse\n\t\t\t\tfs.autoform.type = \"select\"\n\t\t\t\tfs.autoform.options = field.options\n\t\t\t\tif _.has(field, 'firstOption')\n\t\t\t\t\tfs.autoform.firstOption = field.firstOption\n\t\t\t\telse\n\t\t\t\t\tfs.autoform.firstOption = \"\"\n\t\t\t# 因为列表视图右侧过滤器还是用的老表单的lookup和select控件,所以上面的代码始终保持原样需要执行\n\t\t\t# 下面是配置了data_type时,额外处理的逻辑\n\t\t\tif field.data_type and field.data_type != \"text\"\n\t\t\t\tif [\"number\", \"currency\", \"percent\"].indexOf(field.data_type) > -1\n\t\t\t\t\tfsType = Number\n\t\t\t\t\tfs.decimal = true\n\t\t\t\telse if field.data_type == \"boolean\"\n\t\t\t\t\tfsType = Boolean\n\t\t\t\telse\n\t\t\t\t\tfsType = String\n\t\t\t\tfs.type = fsType\n\t\t\t\tif field.multiple\n\t\t\t\t\tfs.type = [fsType]\n\t\t\t\t\t\n\t\t\t\tfs.autoform.options = Creator.getSelectOptions(field)\n\t\telse if field.type == \"currency\"\n\t\t\tfs.type = Number\n\t\t\tfs.autoform.type = \"steedosNumber\"\n\t\t\tfs.autoform.precision = field.precision || 18\n\t\t\tif field?.scale\n\t\t\t\tfs.autoform.scale = field.scale\n\t\t\t\tfs.decimal = true\n\t\t\telse if field?.scale != 0\n\t\t\t\tfs.autoform.scale = 2\n\t\t\t\tfs.decimal = true\n\t\telse if field.type == \"number\"\n\t\t\tfs.type = Number\n\t\t\tfs.autoform.type = \"steedosNumber\"\n\t\t\tfs.autoform.precision = field.precision || 18\n\t\t\tif field?.scale\n\t\t\t\tfs.autoform.scale = field.scale\n\t\t\t\tfs.decimal = true\n\t\telse if field.type == \"boolean\"\n\t\t\tfs.type = Boolean\n\t\t\tif field.readonly\n\t\t\t\tfs.autoform.disabled = true\n\t\t\tfs.autoform.type = \"steedos-boolean-checkbox\"\n\t\telse if field.type == \"toggle\"\n\t\t\tfs.type = Boolean\n\t\t\tif field.readonly\n\t\t\t\tfs.autoform.disabled = true\n\t\t\tfs.autoform.type = \"steedos-boolean-toggle\"\n\t\telse if field.type == \"reference\"\n\t\t\tfs.type = String\n\t\telse if field.type == \"checkbox\"\n\t\t\tfs.type = [String]\n\t\t\tfs.autoform.type = \"select-checkbox\"\n\t\t\tfs.autoform.options = field.options\n\t\telse if field.type == \"file\"\n\t\t\tcollectionName = field.collection || \"files\" # collection 默认是 'files'\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: collectionName\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = collectionName\n\t\telse if field.type == \"filesize\"\n\t\t\tfs.type = Number\n\t\t\tfs.autoform.type = 'filesize'\n\t\telse if field.type == \"Object\" || field.type == \"object\"\n\t\t\tfs.type = Object\n\t\telse if field.type == \"grid\" || field.type == \"table\"\n\t\t\tfs.type = Array\n\t\t\tfs.autoform.editable = true\n\t\t\tfs.autoform.type = \"steedosGrid\"\n\n\t\t\tschema[field_name + \".$\"] =\n\t\t\t\ttype: Object\n\t\telse if field.type == \"image\"\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: 'images'\n\t\t\t\t\t\taccept: 'image/*'\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = 'images'\n\t\t\t\tfs.autoform.accept = 'image/*'\n\t\telse if field.type == \"avatar\"\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: 'avatars'\n\t\t\t\t\t\taccept: 'image/*'\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = 'avatars'\n\t\t\t\tfs.autoform.accept = 'image/*'\n\t\telse if field.type == \"audio\"\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: 'audios'\n\t\t\t\t\t\taccept: 'audio/*'\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = 'audios'\n\t\t\t\tfs.autoform.accept = 'audio/*'\n\t\telse if field.type == \"video\"\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: 'videos'\n\t\t\t\t\t\taccept: 'video/*'\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = 'videos'\n\t\t\t\tfs.autoform.accept = 'video/*'\n\t\telse if field.type == \"location\"\n\t\t\tfs.type = Object\n\t\t\tfs.autoform.type = \"location\"\n\t\t\tfs.autoform.system = field.system || \"wgs84\"\n\t\t\tfs.blackbox = true\n\t\telse if field.type == \"markdown\"\n\t\t\tfs.type = String\n\t\t\tfs.autoform.type = \"text\"\n\t\telse if field.type == 'url'\n\t\t\tfs.type = String\n\t\t\t# fs.regEx = SimpleSchema.RegEx.Url\n\t\t\tfs.autoform.type = 'steedosUrl'\n\t\telse if field.type == 'email'\n\t\t\tfs.type = String\n\t\t\tfs.regEx = SimpleSchema.RegEx.Email\n\t\t\tfs.autoform.type = 'steedosEmail'\n\t\telse if field.type == 'autonumber'\n\t\t\tfs.type = String\n\t\telse if field.type == 'color'\n\t\t\tfs.type = String\n\t\telse if field.type == 'formula'\n\t\t\tfs = Creator.getObjectSchema({fields: {field: Object.assign({}, field, {type: field.data_type})}})[field.name]\n\t\telse if field.type == 'summary'\n\t\t\tfs = Creator.getObjectSchema({fields: {field: Object.assign({}, field, {type: field.data_type})}})[field.name]\n\t\t# else if field.type == 'select'\n\t\t# \tfs = Creator.getObjectSchema({fields: {field: Object.assign({}, field, {type: field.data_type})}})[field.name]\n\t\telse if field.type == 'percent'\n\t\t\tfs.type = Number\n\t\t\tfs.autoform.type = \"steedosNumber\"\n\t\t\tfs.autoform.precision = field.precision || 18\n\t\t\tunless _.isNumber(field.scale)\n\t\t\t\t# 没配置小数位数则按小数位数0来处理,即默认显示为整数的百分比,比如20%,此时控件可以输入2位小数,转成百分比就是整数\n\t\t\t\tfield.scale = 0\n\t\t\t# autoform控件中小数位数始终比配置的位数多2位\n\t\t\tfs.autoform.scale = field.scale + 2\n\t\t\tfs.decimal = true\n\t\telse\n\t\t\tfs.type = field.type\n\n\t\tif field.label\n\t\t\tfs.label = field.label\n\n#\t\tif field.allowedValues\n#\t\t\tfs.allowedValues = field.allowedValues\n\n\t\tif !field.required\n\t\t\tfs.optional = true\n\n\t\t# [签约对象同时配置了company_ids必填及uneditable_fields造成部分用户新建签约对象时报错 #192](https://github.com/steedos/steedos-project-dzug/issues/192)\n\t\t# 后台始终设置required为false\n\t\tif !Meteor.isClient\n\t\t\tfs.optional = true\n\n\t\tif field.unique\n\t\t\tfs.unique = true\n\n\t\tif field.omit\n\t\t\tfs.autoform.omit = true\n\n\t\tif field.group\n\t\t\tfs.autoform.group = field.group\n\n\t\tif field.is_wide\n\t\t\tfs.autoform.is_wide = true\n\n\t\tif field.hidden\n\t\t\tfs.autoform.type = \"hidden\"\n\n\t\tif (field.type == \"select\") or (field.type == \"lookup\") or (field.type == \"master_detail\")\n\t\t\tif typeof(field.filterable) == 'undefined'\n\t\t\t\tfield.filterable = true\n\t\tif field.name == 'name' || field.is_name\n\t\t\tif typeof(field.searchable) == 'undefined'\n\t\t\t\tfield.searchable = true\n\n\t\tif autoform_type\n\t\t\tfs.autoform.type = autoform_type\n\n\t\tif field.defaultValue\n\t\t\tif Meteor.isClient and Creator.Formular.checkFormula(field.defaultValue)\n\t\t\t\tfs.autoform.defaultValue = ()->\n\t\t\t\t\treturn Creator.Formular.run(field.defaultValue, {userId: Meteor.userId(), spaceId: Session.get(\"spaceId\"), now: new Date()})\n\t\t\telse\n\t\t\t\tfs.autoform.defaultValue = field.defaultValue\n\t\t\t# \tif !_.isFunction(field.defaultValue)\n\t\t\t# \t\tfs.defaultValue = field.defaultValue\n\n\t\tif field.readonly\n\t\t\tfs.autoform.readonly = true\n\n\t\tif field.disabled\n\t\t\tfs.autoform.disabled = true\n\n\t\tif field.inlineHelpText\n\t\t\tfs.autoform.inlineHelpText = field.inlineHelpText\n\n\t\tif field.blackbox\n\t\t\tfs.blackbox = true\n\n\t\tif _.has(field, 'min')\n\t\t\tfs.min = field.min\n\t\tif _.has(field, 'max')\n\t\t\tfs.max = field.max\n\n\t\t# 只有生产环境才重建索引\n\t\tif Meteor.isProduction\n\t\t\tif field.index\n\t\t\t\tfs.index = field.index\n\t\t\telse if field.sortable\n\t\t\t\tfs.index = true\n\n\t\tschema[field_name] = fs\n\n\treturn schema\n\n\nCreator.getFieldDisplayValue = (object_name, field_name, field_value)->\n\thtml = field_value\n\tobject = Creator.getObject(object_name)\n\tif !object\n\t\treturn \"\"\n\tfield = object.fields(field_name)\n\tif !field\n\t\treturn \"\"\n\n\tif field.type == \"datetime\"\n\t\thtml = moment(this.val).format('YYYY-MM-DD H:mm')\n\telse if field.type == \"date\"\n\t\thtml = moment(this.val).format('YYYY-MM-DD')\n\n\treturn html\n\nCreator.checkFieldTypeSupportBetweenQuery = (field_type)->\n\treturn [\"date\", \"datetime\", \"time\", \"currency\", \"number\"].includes(field_type)\n\nCreator.pushBetweenBuiltinOptionals = (field_type, operations)->\n\tbuiltinValues = Creator.getBetweenBuiltinValues(field_type)\n\tif builtinValues\n\t\t_.forEach builtinValues, (builtinItem, key)->\n\t\t\toperations.push({label: builtinItem.label, value: key})\n\nCreator.getBetweenBuiltinValues = (field_type, is_check_only)->\n\t# 过滤器字段类型对应的内置选项\n\tif [\"date\", \"datetime\"].includes(field_type)\n\t\treturn Creator.getBetweenTimeBuiltinValues(is_check_only, field_type)\n\nCreator.getBetweenBuiltinValueItem = (field_type, key)->\n\t# 过滤器字段类型对应的内置选项\n\tif [\"date\", \"datetime\"].includes(field_type)\n\t\treturn Creator.getBetweenTimeBuiltinValueItem(field_type, key)\n\nCreator.getBetweenBuiltinOperation = (field_type, value)->\n\t# 根据过滤器的过滤值,获取对应的内置运算符\n\t# 比如value为last_year,返回between_time_last_year\n\tunless _.isString(value)\n\t\treturn\n\tbetweenBuiltinValues = Creator.getBetweenBuiltinValues(field_type)\n\tunless betweenBuiltinValues\n\t\treturn\n\tresult = null\n\t_.each betweenBuiltinValues, (item, operation)->\n\t\tif item.key == value\n\t\t\tresult = operation\n\treturn result\n\n# 如果只是为判断operation是否存在,则没必要计算values,传入is_check_only为true即可\nCreator.getBetweenTimeBuiltinValues = (is_check_only, field_type)->\n\t# 过滤器时间字段类型对应的内置选项\n\treturn {\n\t\t\"between_time_last_year\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_year\"),\n\t\t\"between_time_this_year\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_year\"),\n\t\t\"between_time_next_year\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_year\"),\n\t\t\"between_time_last_quarter\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_quarter\"),\n\t\t\"between_time_this_quarter\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_quarter\"),\n\t\t\"between_time_next_quarter\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_quarter\"),\n\t\t\"between_time_last_month\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_month\"),\n\t\t\"between_time_this_month\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_month\"),\n\t\t\"between_time_next_month\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_month\"),\n\t\t\"between_time_last_week\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_week\"),\n\t\t\"between_time_this_week\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_week\"),\n\t\t\"between_time_next_week\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_week\"),\n\t\t\"between_time_yestday\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"yestday\"),\n\t\t\"between_time_today\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"today\"),\n\t\t\"between_time_tomorrow\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"tomorrow\"),\n\t\t\"between_time_last_7_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_7_days\"),\n\t\t\"between_time_last_30_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_30_days\"),\n\t\t\"between_time_last_60_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_60_days\"),\n\t\t\"between_time_last_90_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_90_days\"),\n\t\t\"between_time_last_120_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_120_days\"),\n\t\t\"between_time_next_7_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_7_days\"),\n\t\t\"between_time_next_30_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_30_days\"),\n\t\t\"between_time_next_60_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_60_days\"),\n\t\t\"between_time_next_90_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_90_days\"),\n\t\t\"between_time_next_120_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_120_days\")\n\t}\n\nCreator.getQuarterStartMonth = (month)->\n\tif !month\n\t\tmonth = new Date().getMonth()\n\t\n\tif month < 3\n\t\treturn 0\n\telse if month < 6\n\t\treturn 3\n\telse if month < 9\n\t\treturn 6\n\t\n\treturn 9\n\n\nCreator.getLastQuarterFirstDay = (year,month)->\n\tif !year\n\t\tyear = new Date().getFullYear()\n\tif !month\n\t\tmonth = new Date().getMonth()\n\t\n\tif month < 3\n\t\tyear--\n\t\tmonth = 9\n\telse if month < 6\n\t\tmonth = 0\n\telse if month < 9\n\t\tmonth = 3\n\telse \n\t\tmonth = 6\n\t\n\treturn new Date(year, month, 1)\n\t\n\nCreator.getNextQuarterFirstDay = (year,month)->\n\tif !year\n\t\tyear = new Date().getFullYear()\n\tif !month\n\t\tmonth = new Date().getMonth()\n\t\n\tif month < 3\n\t\tmonth = 3\n\telse if month < 6\n\t\tmonth = 6\n\telse if month < 9\n\t\tmonth = 9\n\telse\n\t\tyear++\n\t\tmonth = 0\n\t\n\treturn new Date(year, month, 1)\n\nCreator.getMonthDays = (year,month)->\n\tif month == 11\n\t\treturn 31\n\t\n\tmillisecond = 1000 * 60 * 60 * 24\n\tstartDate = new Date(year, month, 1)\n\tendDate = new Date(year, month+1, 1)\n\tdays = (endDate-startDate)/millisecond\n\treturn days\n\nCreator.getLastMonthFirstDay = (year, month)->\n\tif !year\n\t\tyear = new Date().getFullYear()\n\tif !month\n\t\tmonth = new Date().getMonth()\n\t\n\t# 月份为0代表本年的第一月\n\tif month == 0\n\t\tmonth = 11\n\t\tyear--\n\t\treturn new Date(year, month, 1)\n\t\n\t# 否则,只减去月份\n\tmonth--;\n\treturn new Date(year, month, 1)\n\t\nCreator.getBetweenTimeBuiltinValueItem = (field_type, key)->\n\t# 过滤器between运算符,现算日期/日期时间类型字段的values值\n\tnow = new Date()\n\t# 一天的毫秒数\n\tmillisecond = 1000 * 60 * 60 * 24\n\tyestday = new Date(now.getTime() - millisecond)\n\ttomorrow = new Date(now.getTime() + millisecond)\n\t# 一周中的某一天\n\tweek = now.getDay()\n\t# 减去的天数\n\tminusDay = if week != 0 then week - 1 else 6\n\tmonday = new Date(now.getTime() - (minusDay * millisecond))\n\tsunday = new Date(monday.getTime() + (6 * millisecond))\n\t# 上周日\n\tlastSunday = new Date(monday.getTime() - millisecond)\n\t# 上周一\n\tlastMonday = new Date(lastSunday.getTime() - (millisecond * 6))\n\t# 下周一\n\tnextMonday = new Date(sunday.getTime() + millisecond)\n\t# 下周日\n\tnextSunday = new Date(nextMonday.getTime() + (millisecond * 6))\n\tcurrentYear = now.getFullYear()\n\tpreviousYear = currentYear - 1\n\tnextYear = currentYear + 1\n\t# 当前月份\n\tcurrentMonth = now.getMonth()\n\t# 计数年、月\n\tyear = now.getFullYear()\n\tmonth = now.getMonth()\n\t# 本月第一天\n\tfirstDay = new Date(currentYear,currentMonth,1)\n\n\t# 当为12月的时候年份需要加1\n\t# 月份需要更新为0 也就是下一年的第一个月\n\tif currentMonth == 11\n\t\tyear++\n\t\tmonth++\n\telse\n\t\tmonth++\n\t\n\t# 下月第一天\n\tnextMonthFirstDay = new Date(year, month, 1)\n\t# 下月最后一天\n\tnextMonthFinalDay = new Date(year,month,Creator.getMonthDays(year,month))\n\t# 本月最后一天\n\tlastDay = new Date(nextMonthFirstDay.getTime() - millisecond)\n\t# 上月第一天\n\tlastMonthFirstDay = Creator.getLastMonthFirstDay(currentYear,currentMonth)\n\t# 上月最后一天\n\tlastMonthFinalDay = new Date(firstDay.getTime() - millisecond)\n\t# 本季度开始日\n\tthisQuarterStartDay = new Date(currentYear,Creator.getQuarterStartMonth(currentMonth),1)\n\t# 本季度结束日\n\tthisQuarterEndDay = new Date(currentYear,Creator.getQuarterStartMonth(currentMonth)+2,Creator.getMonthDays(currentYear,Creator.getQuarterStartMonth(currentMonth)+2))\n\t# 上季度开始日\n\tlastQuarterStartDay = Creator.getLastQuarterFirstDay(currentYear,currentMonth)\n\t# 上季度结束日\n\tlastQuarterEndDay = new Date(lastQuarterStartDay.getFullYear(),lastQuarterStartDay.getMonth()+2,Creator.getMonthDays(lastQuarterStartDay.getFullYear(),lastQuarterStartDay.getMonth()+2))\n\t# 下季度开始日\n\tnextQuarterStartDay = Creator.getNextQuarterFirstDay(currentYear,currentMonth)\n\t# 下季度结束日\n\tnextQuarterEndDay = new Date(nextQuarterStartDay.getFullYear(),nextQuarterStartDay.getMonth()+2,Creator.getMonthDays(nextQuarterStartDay.getFullYear(),nextQuarterStartDay.getMonth()+2))\n\t# 过去7天 \n\tlast_7_days = new Date(now.getTime() - (6 * millisecond))\n\t# 过去30天\n\tlast_30_days = new Date(now.getTime() - (29 * millisecond))\n\t# 过去60天\n\tlast_60_days = new Date(now.getTime() - (59 * millisecond))\n\t# 过去90天\n\tlast_90_days = new Date(now.getTime() - (89 * millisecond))\n\t# 过去120天\n\tlast_120_days = new Date(now.getTime() - (119 * millisecond))\n\t# 未来7天 \n\tnext_7_days = new Date(now.getTime() + (6 * millisecond))\n\t# 未来30天\n\tnext_30_days = new Date(now.getTime() + (29 * millisecond))\n\t# 未来60天\n\tnext_60_days = new Date(now.getTime() + (59 * millisecond))\n\t# 未来90天\n\tnext_90_days = new Date(now.getTime() + (89 * millisecond))\n\t# 未来120天\n\tnext_120_days = new Date(now.getTime() + (119 * millisecond))\n\n\tswitch key\n\t\twhen \"last_year\"\n\t\t\t#去年\n\t\t\tlabel = t(\"creator_filter_operation_between_last_year\")\n\t\t\tstartValue = new Date(\"#{previousYear}-01-01T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{previousYear}-12-31T23:59:59Z\")\n\t\twhen \"this_year\"\n\t\t\t#今年\n\t\t\tlabel = t(\"creator_filter_operation_between_this_year\")\n\t\t\tstartValue = new Date(\"#{currentYear}-01-01T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{currentYear}-12-31T23:59:59Z\")\n\t\twhen \"next_year\"\n\t\t\t#明年\n\t\t\tlabel = t(\"creator_filter_operation_between_next_year\")\n\t\t\tstartValue = new Date(\"#{nextYear}-01-01T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{nextYear}-12-31T23:59:59Z\")\n\t\twhen \"last_quarter\"\n\t\t\t#上季度\n\t\t\tstrFirstDay = moment(lastQuarterStartDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(lastQuarterEndDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_quarter\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"this_quarter\"\n\t\t\t#本季度\n\t\t\tstrFirstDay = moment(thisQuarterStartDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(thisQuarterEndDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_this_quarter\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"next_quarter\"\n\t\t\t#下季度\n\t\t\tstrFirstDay = moment(nextQuarterStartDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(nextQuarterEndDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_quarter\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"last_month\"\n\t\t\t#上月\n\t\t\tstrFirstDay = moment(lastMonthFirstDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(lastMonthFinalDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_month\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"this_month\"\n\t\t\t#本月\n\t\t\tstrFirstDay = moment(firstDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(lastDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_this_month\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"next_month\"\n\t\t\t#下月\n\t\t\tstrFirstDay = moment(nextMonthFirstDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(nextMonthFinalDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_month\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"last_week\"\n\t\t\t#上周\n\t\t\tstrMonday = moment(lastMonday).format(\"YYYY-MM-DD\")\n\t\t\tstrSunday = moment(lastSunday).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_week\")\n\t\t\tstartValue = new Date(\"#{strMonday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strSunday}T23:59:59Z\")\n\t\twhen \"this_week\"\n\t\t\t#本周\n\t\t\tstrMonday = moment(monday).format(\"YYYY-MM-DD\")\n\t\t\tstrSunday = moment(sunday).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_this_week\")\n\t\t\tstartValue = new Date(\"#{strMonday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strSunday}T23:59:59Z\")\n\t\twhen \"next_week\"\n\t\t\t#下周\n\t\t\tstrMonday = moment(nextMonday).format(\"YYYY-MM-DD\")\n\t\t\tstrSunday = moment(nextSunday).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_week\")\n\t\t\tstartValue = new Date(\"#{strMonday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strSunday}T23:59:59Z\")\n\t\twhen \"yestday\"\n\t\t\t#昨天\n\t\t\tstrYestday = moment(yestday).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_yestday\")\n\t\t\tstartValue = new Date(\"#{strYestday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strYestday}T23:59:59Z\")\n\t\twhen \"today\"\n\t\t\t#今天\n\t\t\tstrToday = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_today\")\n\t\t\tstartValue = new Date(\"#{strToday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strToday}T23:59:59Z\")\n\t\twhen \"tomorrow\"\n\t\t\t#明天\n\t\t\tstrTomorrow = moment(tomorrow).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_tomorrow\")\n\t\t\tstartValue = new Date(\"#{strTomorrow}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strTomorrow}T23:59:59Z\")\n\t\twhen \"last_7_days\"\n\t\t\t#过去7天\n\t\t\tstrStartDay = moment(last_7_days).format(\"YYYY-MM-DD\") \n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_7_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"last_30_days\"\n\t\t\t#过去30天\n\t\t\tstrStartDay = moment(last_30_days).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_30_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"last_60_days\"\n\t\t\t#过去60天\n\t\t\tstrStartDay = moment(last_60_days).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_60_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"last_90_days\"\n\t\t\t#过去90天\n\t\t\tstrStartDay = moment(last_90_days).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_90_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"last_120_days\"\n\t\t\t#过去120天\n\t\t\tstrStartDay = moment(last_120_days).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_120_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_7_days\"\n\t\t\t#未来7天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_7_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_7_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_30_days\"\n\t\t\t#未来30天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_30_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_30_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_60_days\"\n\t\t\t#未来60天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_60_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_60_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_90_days\"\n\t\t\t#未来90天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_90_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_90_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_120_days\"\n\t\t\t#未来120天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_120_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_120_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\n\tvalues = [startValue, endValue]\n\tif field_type == \"datetime\"\n\t\t# 时间类型字段,内置时间范围应该考虑偏移时区值,否则过滤数据存在偏差\n\t\t# 非内置时间范围时,用户通过时间控件选择的范围,会自动处理时区偏差情况\n\t\t# 日期类型字段,数据库本来就存的是UTC的0点,不存在偏差\n\t\t_.forEach values, (fv)->\n\t\t\tif fv\n\t\t\t\tfv.setHours(fv.getHours() + fv.getTimezoneOffset() / 60 )\n\t\n\treturn {\n\t\tlabel: label\n\t\tkey: key\n\t\tvalues: values\n\t}\n\nCreator.getFieldDefaultOperation = (field_type)->\n\tif field_type && Creator.checkFieldTypeSupportBetweenQuery(field_type)\n\t\treturn 'between'\n\telse if [\"textarea\", \"text\", \"code\"].includes(field_type)\n\t\treturn 'contains'\n\telse\n\t\treturn \"=\"\n\nCreator.getFieldOperation = (field_type) ->\n\t# 日期类型: date, datetime 支持操作符: \"=\", \"<>\", \"<\", \">\", \"<=\", \">=\"\n\t# 文本类型: text, textarea, html 支持操作符: \"=\", \"<>\", \"contains\", \"notcontains\", \"startswith\"\n\t# 选择类型: lookup, master_detail, select 支持操作符: \"=\", \"<>\"\n\t# 数值类型: currency, number 支持操作符: \"=\", \"<>\", \"<\", \">\", \"<=\", \">=\"\n\t# 布尔类型: boolean 支持操作符: \"=\", \"<>\"\n\t# 数组类型: checkbox, [text] 支持操作符: \"=\", \"<>\"\n\n\toptionals = {\n\t\tequal: {label: t(\"creator_filter_operation_equal\"), value: \"=\"},\n\t\tunequal: {label: t(\"creator_filter_operation_unequal\"), value: \"<>\"},\n\t\tless_than: {label: t(\"creator_filter_operation_less_than\"), value: \"<\"},\n\t\tgreater_than: {label: t(\"creator_filter_operation_greater_than\"), value: \">\"},\n\t\tless_or_equal: {label: t(\"creator_filter_operation_less_or_equal\"), value: \"<=\"},\n\t\tgreater_or_equal: {label: t(\"creator_filter_operation_greater_or_equal\"), value: \">=\"},\n\t\tcontains: {label: t(\"creator_filter_operation_contains\"), value: \"contains\"},\n\t\tnot_contain: {label: t(\"creator_filter_operation_does_not_contain\"), value: \"notcontains\"},\n\t\tstarts_with: {label: t(\"creator_filter_operation_starts_with\"), value: \"startswith\"},\n\t\tbetween: {label: t(\"creator_filter_operation_between\"), value: \"between\"},\n\t}\n\n\tif field_type == undefined\n\t\treturn _.values(optionals)\n\n\toperations = []\n\n\tif Creator.checkFieldTypeSupportBetweenQuery(field_type)\n\t\toperations.push(optionals.between)\n\t\tCreator.pushBetweenBuiltinOptionals(field_type, operations)\n\telse if field_type == \"text\" or field_type == \"textarea\" or field_type == \"html\" or field_type == \"code\"\n#\t\toperations.push(optionals.equal, optionals.unequal, optionals.contains, optionals.not_contain, optionals.starts_with)\n\t\toperations.push(optionals.contains)\n\telse if field_type == \"lookup\" or field_type == \"master_detail\" or field_type == \"select\"\n\t\toperations.push(optionals.equal, optionals.unequal)\n\telse if field_type == \"currency\" or field_type == \"number\"\n\t\toperations.push(optionals.equal, optionals.unequal, optionals.less_than, optionals.greater_than, optionals.less_or_equal, optionals.greater_or_equal)\n\telse if field_type == \"boolean\"\n\t\toperations.push(optionals.equal, optionals.unequal)\n\telse if field_type == \"checkbox\"\n\t\toperations.push(optionals.equal, optionals.unequal)\n\telse if field_type == \"[text]\"\n\t\toperations.push(optionals.equal, optionals.unequal)\n\telse\n\t\toperations.push(optionals.equal, optionals.unequal)\n\n\treturn operations\n\n###\n 先按照有排序号的小的在前,大的在后\n 再将没有排序号的显示在\n###\nCreator.getObjectFieldsName = (object_name)->\n\tfields = Creator.getObject(object_name)?.fields\n\tfieldsArr = []\n\n\t_.each fields, (field)->\n\t\tfieldsArr.push {name: field.name, sort_no: field.sort_no}\n\n\tfieldsName = []\n\t_.each _.sortBy(fieldsArr, \"sort_no\"), (field)->\n\t\tfieldsName.push(field.name)\n\treturn fieldsName\n","Creator.getSelectOptions = function(fieldSchema) {\n var data_type, options;\n options = fieldSchema.options;\n if (!options) {\n return;\n }\n data_type = fieldSchema.data_type;\n if (!_.isFunction(options) && data_type && data_type !== 'text') {\n options.forEach(function(optionItem) {\n if (typeof optionItem.value !== 'string') {\n return;\n }\n if (['number', 'currency', 'percent'].indexOf(data_type) > -1) {\n return optionItem.value = Number(optionItem.value);\n } else if (data_type === 'boolean') {\n return optionItem.value = optionItem.value === 'true';\n }\n });\n }\n return options;\n};\n\nCreator.getObjectSchema = function(obj) {\n var fieldsArr, schema;\n if (!obj) {\n return;\n }\n schema = {};\n fieldsArr = [];\n _.each(obj.fields, function(field, field_name) {\n if (!_.has(field, \"name\")) {\n field.name = field_name;\n }\n return fieldsArr.push(field);\n });\n _.each(_.sortBy(fieldsArr, \"sort_no\"), function(field) {\n var _object, _ref_obj, _reference_to, autoform_type, collectionName, field_name, fs, fsType, isUnLimited, permissions, ref, ref1;\n field_name = field.name;\n fs = {};\n if (field.regEx) {\n fs.regEx = field.regEx;\n }\n fs.autoform = {};\n fs.autoform.multiple = field.multiple;\n fs.autoform.reference_to = field.reference_to;\n autoform_type = (ref = field.autoform) != null ? ref.type : void 0;\n if (field.type === \"text\" || field.type === \"phone\") {\n fs.type = String;\n if (field.multiple) {\n fs.type = [String];\n fs.autoform.type = \"tags\";\n }\n } else if (field.type === \"[text]\" || field.type === \"[phone]\") {\n fs.type = [String];\n fs.autoform.type = \"tags\";\n } else if (field.type === 'code') {\n fs.type = String;\n fs.autoform.type = \"widearea\";\n fs.autoform.rows = field.rows || 12;\n if (field.language) {\n fs.autoform.language = field.language;\n }\n } else if (field.type === \"textarea\") {\n fs.type = String;\n fs.autoform.type = \"widearea\";\n fs.autoform.rows = field.rows || 2;\n } else if (field.type === \"password\") {\n fs.type = String;\n fs.autoform.type = \"password\";\n } else if (field.type === \"date\") {\n fs.type = Date;\n if (Meteor.isClient) {\n if (Steedos.isMobile() || Steedos.isPad()) {\n if (Steedos.isiOS()) {\n fs.autoform.afFieldInput = {\n type: \"dx-date-box\",\n timezoneId: \"utc\",\n dxDateBoxOptions: {\n type: \"date\",\n displayFormat: \"yyyy-MM-dd\",\n pickerType: \"rollers\"\n }\n };\n } else {\n fs.autoform.afFieldInput = {\n type: \"steedos-date-mobile\",\n dateMobileOptions: {\n type: \"date\"\n }\n };\n }\n } else {\n fs.autoform.outFormat = 'yyyy-MM-dd';\n fs.autoform.afFieldInput = {\n type: \"dx-date-box\",\n timezoneId: \"utc\",\n dxDateBoxOptions: {\n type: \"date\",\n displayFormat: \"yyyy-MM-dd\"\n }\n };\n }\n }\n } else if (field.type === \"time\") {\n fs.type = Date;\n if (Meteor.isClient) {\n fs.autoform.afFieldInput = {\n type: \"dx-date-box\",\n timezoneId: \"utc\",\n dxDateBoxOptions: {\n type: \"time\",\n displayFormat: \"HH:mm\"\n }\n };\n }\n } else if (field.type === \"datetime\") {\n fs.type = Date;\n if (Meteor.isClient) {\n if (Steedos.isMobile() || Steedos.isPad()) {\n if (Steedos.isiOS()) {\n fs.autoform.afFieldInput = {\n type: \"dx-date-box\",\n dxDateBoxOptions: {\n type: \"datetime\",\n displayFormat: \"yyyy-MM-dd HH:mm\",\n pickerType: \"rollers\"\n }\n };\n } else {\n fs.autoform.afFieldInput = {\n type: \"steedos-date-mobile\",\n dateMobileOptions: {\n type: \"datetime\"\n }\n };\n }\n } else {\n fs.autoform.afFieldInput = {\n type: \"dx-date-box\",\n dxDateBoxOptions: {\n type: \"datetime\",\n displayFormat: \"yyyy-MM-dd HH:mm\"\n }\n };\n }\n }\n } else if (field.type === \"[Object]\") {\n fs.type = [Object];\n } else if (field.type === \"html\") {\n fs.type = String;\n if (Meteor.isClient) {\n fs.autoform.type = 'steedosHtml';\n }\n } else if (field.type === \"lookup\" || field.type === \"master_detail\") {\n fs.type = String;\n fs.autoform.showIcon = field.showIcon;\n if (field.multiple) {\n fs.type = [String];\n }\n if (!field.hidden) {\n fs.autoform.filters = field.filters;\n fs.autoform.dependOn = field.depend_on;\n if (field.beforeOpenFunction) {\n fs.beforeOpenFunction = field.beforeOpenFunction;\n }\n fs.filtersFunction = field.filtersFunction ? field.filtersFunction : Creator.evaluateFilters;\n if (field.optionsFunction) {\n fs.optionsFunction = field.optionsFunction;\n }\n if (field.reference_to) {\n if (Meteor.isClient) {\n if (field.createFunction && _.isFunction(field.createFunction)) {\n fs.createFunction = field.createFunction;\n } else {\n if (_.isString(field.reference_to)) {\n _ref_obj = Creator.Objects[field.reference_to];\n if (_ref_obj != null ? (ref1 = _ref_obj.permissions) != null ? ref1.allowCreate : void 0 : void 0) {\n fs.autoform.create = true;\n fs.createFunction = function(lookup_field) {\n return Modal.show(\"CreatorObjectModal\", {\n collection: \"Creator.Collections.\" + (Creator.getCollection(field.reference_to)._name),\n formId: \"new\" + (field.reference_to.replace('.', '_')),\n object_name: \"\" + field.reference_to,\n operation: \"insert\",\n onSuccess: function(operation, result) {\n var object;\n object = Creator.getObject(result.object_name);\n if (result.object_name === \"objects\") {\n return lookup_field.addItems([\n {\n label: result.value.label,\n value: result.value.name,\n icon: result.value.icon\n }\n ], result.value.name);\n } else {\n return lookup_field.addItems([\n {\n label: result.value[object.NAME_FIELD_KEY] || result.value.label || result.value.name,\n value: result._id\n }\n ], result._id);\n }\n }\n });\n };\n } else {\n fs.autoform.create = false;\n }\n }\n }\n }\n if (_.isBoolean(field.create)) {\n fs.autoform.create = field.create;\n }\n if (field.reference_sort) {\n fs.autoform.optionsSort = field.reference_sort;\n }\n if (field.reference_limit) {\n fs.autoform.optionsLimit = field.reference_limit;\n }\n if (field.reference_to_field) {\n fs.autoform.referenceToField = field.reference_to_field;\n }\n if (field.reference_to === \"users\") {\n fs.autoform.type = \"selectuser\";\n if (!field.hidden && !field.omit) {\n if (field.is_company_limited === void 0) {\n if (Meteor.isClient) {\n permissions = obj.permissions;\n isUnLimited = permissions != null ? permissions.viewAllRecords : void 0;\n if (_.include([\"organizations\", \"users\", \"space_users\"], obj.name)) {\n isUnLimited = permissions != null ? permissions.modifyAllRecords : void 0;\n }\n if (isUnLimited) {\n fs.autoform.is_company_limited = false;\n } else {\n fs.autoform.is_company_limited = true;\n }\n }\n } else if (_.isFunction(field.is_company_limited)) {\n if (Meteor.isClient) {\n fs.autoform.is_company_limited = field.is_company_limited(obj.permissions);\n } else {\n fs.autoform.is_company_limited = true;\n }\n } else {\n fs.autoform.is_company_limited = field.is_company_limited;\n }\n } else {\n fs.autoform.is_company_limited = field.is_company_limited;\n }\n } else if (field.reference_to === \"organizations\") {\n fs.autoform.type = \"selectorg\";\n if (!field.hidden && !field.omit) {\n if (field.is_company_limited === void 0) {\n if (Meteor.isClient) {\n permissions = obj.permissions;\n isUnLimited = permissions != null ? permissions.viewAllRecords : void 0;\n if (_.include([\"organizations\", \"users\", \"space_users\"], obj.name)) {\n isUnLimited = permissions != null ? permissions.modifyAllRecords : void 0;\n }\n if (isUnLimited) {\n fs.autoform.is_company_limited = false;\n } else {\n fs.autoform.is_company_limited = true;\n }\n }\n } else if (_.isFunction(field.is_company_limited)) {\n if (Meteor.isClient) {\n fs.autoform.is_company_limited = field.is_company_limited(obj.permissions);\n } else {\n fs.autoform.is_company_limited = true;\n }\n } else {\n fs.autoform.is_company_limited = field.is_company_limited;\n }\n } else {\n fs.autoform.is_company_limited = field.is_company_limited;\n }\n } else {\n if (typeof field.reference_to === \"function\") {\n _reference_to = field.reference_to();\n } else {\n _reference_to = field.reference_to;\n }\n if (_.isArray(_reference_to)) {\n fs.type = Object;\n fs.blackbox = true;\n fs.autoform.objectSwitche = true;\n schema[field_name + \".o\"] = {\n type: String,\n autoform: {\n omit: true\n }\n };\n schema[field_name + \".ids\"] = {\n type: [String],\n autoform: {\n omit: true\n }\n };\n } else {\n _reference_to = [_reference_to];\n }\n _object = Creator.Objects[_reference_to[0]];\n if (_object && _object.enable_tree) {\n fs.autoform.type = \"selectTree\";\n } else {\n fs.autoform.type = \"steedosLookups\";\n fs.autoform.optionsMethod = field.optionsMethod || \"creator.object_options\";\n if (Meteor.isClient) {\n fs.autoform.optionsMethodParams = function() {\n return {\n space: Session.get(\"spaceId\")\n };\n };\n fs.autoform.references = [];\n _reference_to.forEach(function(_reference) {\n _object = Creator.Objects[_reference];\n if (_object) {\n return fs.autoform.references.push({\n object: _reference,\n label: _object != null ? _object.label : void 0,\n icon: _object != null ? _object.icon : void 0,\n link: function() {\n return \"/app/\" + (Session.get('app_id')) + \"/\" + _reference + \"/view/\";\n }\n });\n } else {\n return fs.autoform.references.push({\n object: _reference,\n link: function() {\n return \"/app/\" + (Session.get('app_id')) + \"/\" + _reference + \"/view/\";\n }\n });\n }\n });\n }\n }\n }\n } else {\n fs.autoform.type = \"steedosLookups\";\n fs.autoform.defaultIcon = field.defaultIcon;\n }\n }\n } else if (field.type === \"select\") {\n fs.type = String;\n if (field.multiple) {\n fs.type = [String];\n fs.autoform.type = \"steedosLookups\";\n fs.autoform.showIcon = false;\n fs.autoform.options = field.options;\n } else {\n fs.autoform.type = \"select\";\n fs.autoform.options = field.options;\n if (_.has(field, 'firstOption')) {\n fs.autoform.firstOption = field.firstOption;\n } else {\n fs.autoform.firstOption = \"\";\n }\n }\n if (field.data_type && field.data_type !== \"text\") {\n if ([\"number\", \"currency\", \"percent\"].indexOf(field.data_type) > -1) {\n fsType = Number;\n fs.decimal = true;\n } else if (field.data_type === \"boolean\") {\n fsType = Boolean;\n } else {\n fsType = String;\n }\n fs.type = fsType;\n if (field.multiple) {\n fs.type = [fsType];\n }\n fs.autoform.options = Creator.getSelectOptions(field);\n }\n } else if (field.type === \"currency\") {\n fs.type = Number;\n fs.autoform.type = \"steedosNumber\";\n fs.autoform.precision = field.precision || 18;\n if (field != null ? field.scale : void 0) {\n fs.autoform.scale = field.scale;\n fs.decimal = true;\n } else if ((field != null ? field.scale : void 0) !== 0) {\n fs.autoform.scale = 2;\n fs.decimal = true;\n }\n } else if (field.type === \"number\") {\n fs.type = Number;\n fs.autoform.type = \"steedosNumber\";\n fs.autoform.precision = field.precision || 18;\n if (field != null ? field.scale : void 0) {\n fs.autoform.scale = field.scale;\n fs.decimal = true;\n }\n } else if (field.type === \"boolean\") {\n fs.type = Boolean;\n if (field.readonly) {\n fs.autoform.disabled = true;\n }\n fs.autoform.type = \"steedos-boolean-checkbox\";\n } else if (field.type === \"toggle\") {\n fs.type = Boolean;\n if (field.readonly) {\n fs.autoform.disabled = true;\n }\n fs.autoform.type = \"steedos-boolean-toggle\";\n } else if (field.type === \"reference\") {\n fs.type = String;\n } else if (field.type === \"checkbox\") {\n fs.type = [String];\n fs.autoform.type = \"select-checkbox\";\n fs.autoform.options = field.options;\n } else if (field.type === \"file\") {\n collectionName = field.collection || \"files\";\n if (field.multiple) {\n fs.type = [String];\n schema[field_name + \".$\"] = {\n autoform: {\n type: 'fileUpload',\n collection: collectionName\n }\n };\n } else {\n fs.type = String;\n fs.autoform.type = 'fileUpload';\n fs.autoform.collection = collectionName;\n }\n } else if (field.type === \"filesize\") {\n fs.type = Number;\n fs.autoform.type = 'filesize';\n } else if (field.type === \"Object\" || field.type === \"object\") {\n fs.type = Object;\n } else if (field.type === \"grid\" || field.type === \"table\") {\n fs.type = Array;\n fs.autoform.editable = true;\n fs.autoform.type = \"steedosGrid\";\n schema[field_name + \".$\"] = {\n type: Object\n };\n } else if (field.type === \"image\") {\n if (field.multiple) {\n fs.type = [String];\n schema[field_name + \".$\"] = {\n autoform: {\n type: 'fileUpload',\n collection: 'images',\n accept: 'image/*'\n }\n };\n } else {\n fs.type = String;\n fs.autoform.type = 'fileUpload';\n fs.autoform.collection = 'images';\n fs.autoform.accept = 'image/*';\n }\n } else if (field.type === \"avatar\") {\n if (field.multiple) {\n fs.type = [String];\n schema[field_name + \".$\"] = {\n autoform: {\n type: 'fileUpload',\n collection: 'avatars',\n accept: 'image/*'\n }\n };\n } else {\n fs.type = String;\n fs.autoform.type = 'fileUpload';\n fs.autoform.collection = 'avatars';\n fs.autoform.accept = 'image/*';\n }\n } else if (field.type === \"audio\") {\n if (field.multiple) {\n fs.type = [String];\n schema[field_name + \".$\"] = {\n autoform: {\n type: 'fileUpload',\n collection: 'audios',\n accept: 'audio/*'\n }\n };\n } else {\n fs.type = String;\n fs.autoform.type = 'fileUpload';\n fs.autoform.collection = 'audios';\n fs.autoform.accept = 'audio/*';\n }\n } else if (field.type === \"video\") {\n if (field.multiple) {\n fs.type = [String];\n schema[field_name + \".$\"] = {\n autoform: {\n type: 'fileUpload',\n collection: 'videos',\n accept: 'video/*'\n }\n };\n } else {\n fs.type = String;\n fs.autoform.type = 'fileUpload';\n fs.autoform.collection = 'videos';\n fs.autoform.accept = 'video/*';\n }\n } else if (field.type === \"location\") {\n fs.type = Object;\n fs.autoform.type = \"location\";\n fs.autoform.system = field.system || \"wgs84\";\n fs.blackbox = true;\n } else if (field.type === \"markdown\") {\n fs.type = String;\n fs.autoform.type = \"text\";\n } else if (field.type === 'url') {\n fs.type = String;\n fs.autoform.type = 'steedosUrl';\n } else if (field.type === 'email') {\n fs.type = String;\n fs.regEx = SimpleSchema.RegEx.Email;\n fs.autoform.type = 'steedosEmail';\n } else if (field.type === 'autonumber') {\n fs.type = String;\n } else if (field.type === 'color') {\n fs.type = String;\n } else if (field.type === 'formula') {\n fs = Creator.getObjectSchema({\n fields: {\n field: Object.assign({}, field, {\n type: field.data_type\n })\n }\n })[field.name];\n } else if (field.type === 'summary') {\n fs = Creator.getObjectSchema({\n fields: {\n field: Object.assign({}, field, {\n type: field.data_type\n })\n }\n })[field.name];\n } else if (field.type === 'percent') {\n fs.type = Number;\n fs.autoform.type = \"steedosNumber\";\n fs.autoform.precision = field.precision || 18;\n if (!_.isNumber(field.scale)) {\n field.scale = 0;\n }\n fs.autoform.scale = field.scale + 2;\n fs.decimal = true;\n } else {\n fs.type = field.type;\n }\n if (field.label) {\n fs.label = field.label;\n }\n if (!field.required) {\n fs.optional = true;\n }\n if (!Meteor.isClient) {\n fs.optional = true;\n }\n if (field.unique) {\n fs.unique = true;\n }\n if (field.omit) {\n fs.autoform.omit = true;\n }\n if (field.group) {\n fs.autoform.group = field.group;\n }\n if (field.is_wide) {\n fs.autoform.is_wide = true;\n }\n if (field.hidden) {\n fs.autoform.type = \"hidden\";\n }\n if ((field.type === \"select\") || (field.type === \"lookup\") || (field.type === \"master_detail\")) {\n if (typeof field.filterable === 'undefined') {\n field.filterable = true;\n }\n }\n if (field.name === 'name' || field.is_name) {\n if (typeof field.searchable === 'undefined') {\n field.searchable = true;\n }\n }\n if (autoform_type) {\n fs.autoform.type = autoform_type;\n }\n if (field.defaultValue) {\n if (Meteor.isClient && Creator.Formular.checkFormula(field.defaultValue)) {\n fs.autoform.defaultValue = function() {\n return Creator.Formular.run(field.defaultValue, {\n userId: Meteor.userId(),\n spaceId: Session.get(\"spaceId\"),\n now: new Date()\n });\n };\n } else {\n fs.autoform.defaultValue = field.defaultValue;\n }\n }\n if (field.readonly) {\n fs.autoform.readonly = true;\n }\n if (field.disabled) {\n fs.autoform.disabled = true;\n }\n if (field.inlineHelpText) {\n fs.autoform.inlineHelpText = field.inlineHelpText;\n }\n if (field.blackbox) {\n fs.blackbox = true;\n }\n if (_.has(field, 'min')) {\n fs.min = field.min;\n }\n if (_.has(field, 'max')) {\n fs.max = field.max;\n }\n if (Meteor.isProduction) {\n if (field.index) {\n fs.index = field.index;\n } else if (field.sortable) {\n fs.index = true;\n }\n }\n return schema[field_name] = fs;\n });\n return schema;\n};\n\nCreator.getFieldDisplayValue = function(object_name, field_name, field_value) {\n var field, html, object;\n html = field_value;\n object = Creator.getObject(object_name);\n if (!object) {\n return \"\";\n }\n field = object.fields(field_name);\n if (!field) {\n return \"\";\n }\n if (field.type === \"datetime\") {\n html = moment(this.val).format('YYYY-MM-DD H:mm');\n } else if (field.type === \"date\") {\n html = moment(this.val).format('YYYY-MM-DD');\n }\n return html;\n};\n\nCreator.checkFieldTypeSupportBetweenQuery = function(field_type) {\n return [\"date\", \"datetime\", \"time\", \"currency\", \"number\"].includes(field_type);\n};\n\nCreator.pushBetweenBuiltinOptionals = function(field_type, operations) {\n var builtinValues;\n builtinValues = Creator.getBetweenBuiltinValues(field_type);\n if (builtinValues) {\n return _.forEach(builtinValues, function(builtinItem, key) {\n return operations.push({\n label: builtinItem.label,\n value: key\n });\n });\n }\n};\n\nCreator.getBetweenBuiltinValues = function(field_type, is_check_only) {\n if ([\"date\", \"datetime\"].includes(field_type)) {\n return Creator.getBetweenTimeBuiltinValues(is_check_only, field_type);\n }\n};\n\nCreator.getBetweenBuiltinValueItem = function(field_type, key) {\n if ([\"date\", \"datetime\"].includes(field_type)) {\n return Creator.getBetweenTimeBuiltinValueItem(field_type, key);\n }\n};\n\nCreator.getBetweenBuiltinOperation = function(field_type, value) {\n var betweenBuiltinValues, result;\n if (!_.isString(value)) {\n return;\n }\n betweenBuiltinValues = Creator.getBetweenBuiltinValues(field_type);\n if (!betweenBuiltinValues) {\n return;\n }\n result = null;\n _.each(betweenBuiltinValues, function(item, operation) {\n if (item.key === value) {\n return result = operation;\n }\n });\n return result;\n};\n\nCreator.getBetweenTimeBuiltinValues = function(is_check_only, field_type) {\n return {\n \"between_time_last_year\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_year\"),\n \"between_time_this_year\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_year\"),\n \"between_time_next_year\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_year\"),\n \"between_time_last_quarter\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_quarter\"),\n \"between_time_this_quarter\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_quarter\"),\n \"between_time_next_quarter\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_quarter\"),\n \"between_time_last_month\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_month\"),\n \"between_time_this_month\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_month\"),\n \"between_time_next_month\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_month\"),\n \"between_time_last_week\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_week\"),\n \"between_time_this_week\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_week\"),\n \"between_time_next_week\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_week\"),\n \"between_time_yestday\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"yestday\"),\n \"between_time_today\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"today\"),\n \"between_time_tomorrow\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"tomorrow\"),\n \"between_time_last_7_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_7_days\"),\n \"between_time_last_30_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_30_days\"),\n \"between_time_last_60_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_60_days\"),\n \"between_time_last_90_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_90_days\"),\n \"between_time_last_120_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_120_days\"),\n \"between_time_next_7_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_7_days\"),\n \"between_time_next_30_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_30_days\"),\n \"between_time_next_60_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_60_days\"),\n \"between_time_next_90_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_90_days\"),\n \"between_time_next_120_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_120_days\")\n };\n};\n\nCreator.getQuarterStartMonth = function(month) {\n if (!month) {\n month = new Date().getMonth();\n }\n if (month < 3) {\n return 0;\n } else if (month < 6) {\n return 3;\n } else if (month < 9) {\n return 6;\n }\n return 9;\n};\n\nCreator.getLastQuarterFirstDay = function(year, month) {\n if (!year) {\n year = new Date().getFullYear();\n }\n if (!month) {\n month = new Date().getMonth();\n }\n if (month < 3) {\n year--;\n month = 9;\n } else if (month < 6) {\n month = 0;\n } else if (month < 9) {\n month = 3;\n } else {\n month = 6;\n }\n return new Date(year, month, 1);\n};\n\nCreator.getNextQuarterFirstDay = function(year, month) {\n if (!year) {\n year = new Date().getFullYear();\n }\n if (!month) {\n month = new Date().getMonth();\n }\n if (month < 3) {\n month = 3;\n } else if (month < 6) {\n month = 6;\n } else if (month < 9) {\n month = 9;\n } else {\n year++;\n month = 0;\n }\n return new Date(year, month, 1);\n};\n\nCreator.getMonthDays = function(year, month) {\n var days, endDate, millisecond, startDate;\n if (month === 11) {\n return 31;\n }\n millisecond = 1000 * 60 * 60 * 24;\n startDate = new Date(year, month, 1);\n endDate = new Date(year, month + 1, 1);\n days = (endDate - startDate) / millisecond;\n return days;\n};\n\nCreator.getLastMonthFirstDay = function(year, month) {\n if (!year) {\n year = new Date().getFullYear();\n }\n if (!month) {\n month = new Date().getMonth();\n }\n if (month === 0) {\n month = 11;\n year--;\n return new Date(year, month, 1);\n }\n month--;\n return new Date(year, month, 1);\n};\n\nCreator.getBetweenTimeBuiltinValueItem = function(field_type, key) {\n var currentMonth, currentYear, endValue, firstDay, label, lastDay, lastMonday, lastMonthFinalDay, lastMonthFirstDay, lastQuarterEndDay, lastQuarterStartDay, lastSunday, last_120_days, last_30_days, last_60_days, last_7_days, last_90_days, millisecond, minusDay, monday, month, nextMonday, nextMonthFinalDay, nextMonthFirstDay, nextQuarterEndDay, nextQuarterStartDay, nextSunday, nextYear, next_120_days, next_30_days, next_60_days, next_7_days, next_90_days, now, previousYear, startValue, strEndDay, strFirstDay, strLastDay, strMonday, strStartDay, strSunday, strToday, strTomorrow, strYestday, sunday, thisQuarterEndDay, thisQuarterStartDay, tomorrow, values, week, year, yestday;\n now = new Date();\n millisecond = 1000 * 60 * 60 * 24;\n yestday = new Date(now.getTime() - millisecond);\n tomorrow = new Date(now.getTime() + millisecond);\n week = now.getDay();\n minusDay = week !== 0 ? week - 1 : 6;\n monday = new Date(now.getTime() - (minusDay * millisecond));\n sunday = new Date(monday.getTime() + (6 * millisecond));\n lastSunday = new Date(monday.getTime() - millisecond);\n lastMonday = new Date(lastSunday.getTime() - (millisecond * 6));\n nextMonday = new Date(sunday.getTime() + millisecond);\n nextSunday = new Date(nextMonday.getTime() + (millisecond * 6));\n currentYear = now.getFullYear();\n previousYear = currentYear - 1;\n nextYear = currentYear + 1;\n currentMonth = now.getMonth();\n year = now.getFullYear();\n month = now.getMonth();\n firstDay = new Date(currentYear, currentMonth, 1);\n if (currentMonth === 11) {\n year++;\n month++;\n } else {\n month++;\n }\n nextMonthFirstDay = new Date(year, month, 1);\n nextMonthFinalDay = new Date(year, month, Creator.getMonthDays(year, month));\n lastDay = new Date(nextMonthFirstDay.getTime() - millisecond);\n lastMonthFirstDay = Creator.getLastMonthFirstDay(currentYear, currentMonth);\n lastMonthFinalDay = new Date(firstDay.getTime() - millisecond);\n thisQuarterStartDay = new Date(currentYear, Creator.getQuarterStartMonth(currentMonth), 1);\n thisQuarterEndDay = new Date(currentYear, Creator.getQuarterStartMonth(currentMonth) + 2, Creator.getMonthDays(currentYear, Creator.getQuarterStartMonth(currentMonth) + 2));\n lastQuarterStartDay = Creator.getLastQuarterFirstDay(currentYear, currentMonth);\n lastQuarterEndDay = new Date(lastQuarterStartDay.getFullYear(), lastQuarterStartDay.getMonth() + 2, Creator.getMonthDays(lastQuarterStartDay.getFullYear(), lastQuarterStartDay.getMonth() + 2));\n nextQuarterStartDay = Creator.getNextQuarterFirstDay(currentYear, currentMonth);\n nextQuarterEndDay = new Date(nextQuarterStartDay.getFullYear(), nextQuarterStartDay.getMonth() + 2, Creator.getMonthDays(nextQuarterStartDay.getFullYear(), nextQuarterStartDay.getMonth() + 2));\n last_7_days = new Date(now.getTime() - (6 * millisecond));\n last_30_days = new Date(now.getTime() - (29 * millisecond));\n last_60_days = new Date(now.getTime() - (59 * millisecond));\n last_90_days = new Date(now.getTime() - (89 * millisecond));\n last_120_days = new Date(now.getTime() - (119 * millisecond));\n next_7_days = new Date(now.getTime() + (6 * millisecond));\n next_30_days = new Date(now.getTime() + (29 * millisecond));\n next_60_days = new Date(now.getTime() + (59 * millisecond));\n next_90_days = new Date(now.getTime() + (89 * millisecond));\n next_120_days = new Date(now.getTime() + (119 * millisecond));\n switch (key) {\n case \"last_year\":\n label = t(\"creator_filter_operation_between_last_year\");\n startValue = new Date(previousYear + \"-01-01T00:00:00Z\");\n endValue = new Date(previousYear + \"-12-31T23:59:59Z\");\n break;\n case \"this_year\":\n label = t(\"creator_filter_operation_between_this_year\");\n startValue = new Date(currentYear + \"-01-01T00:00:00Z\");\n endValue = new Date(currentYear + \"-12-31T23:59:59Z\");\n break;\n case \"next_year\":\n label = t(\"creator_filter_operation_between_next_year\");\n startValue = new Date(nextYear + \"-01-01T00:00:00Z\");\n endValue = new Date(nextYear + \"-12-31T23:59:59Z\");\n break;\n case \"last_quarter\":\n strFirstDay = moment(lastQuarterStartDay).format(\"YYYY-MM-DD\");\n strLastDay = moment(lastQuarterEndDay).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_last_quarter\");\n startValue = new Date(strFirstDay + \"T00:00:00Z\");\n endValue = new Date(strLastDay + \"T23:59:59Z\");\n break;\n case \"this_quarter\":\n strFirstDay = moment(thisQuarterStartDay).format(\"YYYY-MM-DD\");\n strLastDay = moment(thisQuarterEndDay).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_this_quarter\");\n startValue = new Date(strFirstDay + \"T00:00:00Z\");\n endValue = new Date(strLastDay + \"T23:59:59Z\");\n break;\n case \"next_quarter\":\n strFirstDay = moment(nextQuarterStartDay).format(\"YYYY-MM-DD\");\n strLastDay = moment(nextQuarterEndDay).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_next_quarter\");\n startValue = new Date(strFirstDay + \"T00:00:00Z\");\n endValue = new Date(strLastDay + \"T23:59:59Z\");\n break;\n case \"last_month\":\n strFirstDay = moment(lastMonthFirstDay).format(\"YYYY-MM-DD\");\n strLastDay = moment(lastMonthFinalDay).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_last_month\");\n startValue = new Date(strFirstDay + \"T00:00:00Z\");\n endValue = new Date(strLastDay + \"T23:59:59Z\");\n break;\n case \"this_month\":\n strFirstDay = moment(firstDay).format(\"YYYY-MM-DD\");\n strLastDay = moment(lastDay).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_this_month\");\n startValue = new Date(strFirstDay + \"T00:00:00Z\");\n endValue = new Date(strLastDay + \"T23:59:59Z\");\n break;\n case \"next_month\":\n strFirstDay = moment(nextMonthFirstDay).format(\"YYYY-MM-DD\");\n strLastDay = moment(nextMonthFinalDay).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_next_month\");\n startValue = new Date(strFirstDay + \"T00:00:00Z\");\n endValue = new Date(strLastDay + \"T23:59:59Z\");\n break;\n case \"last_week\":\n strMonday = moment(lastMonday).format(\"YYYY-MM-DD\");\n strSunday = moment(lastSunday).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_last_week\");\n startValue = new Date(strMonday + \"T00:00:00Z\");\n endValue = new Date(strSunday + \"T23:59:59Z\");\n break;\n case \"this_week\":\n strMonday = moment(monday).format(\"YYYY-MM-DD\");\n strSunday = moment(sunday).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_this_week\");\n startValue = new Date(strMonday + \"T00:00:00Z\");\n endValue = new Date(strSunday + \"T23:59:59Z\");\n break;\n case \"next_week\":\n strMonday = moment(nextMonday).format(\"YYYY-MM-DD\");\n strSunday = moment(nextSunday).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_next_week\");\n startValue = new Date(strMonday + \"T00:00:00Z\");\n endValue = new Date(strSunday + \"T23:59:59Z\");\n break;\n case \"yestday\":\n strYestday = moment(yestday).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_yestday\");\n startValue = new Date(strYestday + \"T00:00:00Z\");\n endValue = new Date(strYestday + \"T23:59:59Z\");\n break;\n case \"today\":\n strToday = moment(now).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_today\");\n startValue = new Date(strToday + \"T00:00:00Z\");\n endValue = new Date(strToday + \"T23:59:59Z\");\n break;\n case \"tomorrow\":\n strTomorrow = moment(tomorrow).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_tomorrow\");\n startValue = new Date(strTomorrow + \"T00:00:00Z\");\n endValue = new Date(strTomorrow + \"T23:59:59Z\");\n break;\n case \"last_7_days\":\n strStartDay = moment(last_7_days).format(\"YYYY-MM-DD\");\n strEndDay = moment(now).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_last_7_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n break;\n case \"last_30_days\":\n strStartDay = moment(last_30_days).format(\"YYYY-MM-DD\");\n strEndDay = moment(now).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_last_30_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n break;\n case \"last_60_days\":\n strStartDay = moment(last_60_days).format(\"YYYY-MM-DD\");\n strEndDay = moment(now).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_last_60_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n break;\n case \"last_90_days\":\n strStartDay = moment(last_90_days).format(\"YYYY-MM-DD\");\n strEndDay = moment(now).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_last_90_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n break;\n case \"last_120_days\":\n strStartDay = moment(last_120_days).format(\"YYYY-MM-DD\");\n strEndDay = moment(now).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_last_120_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n break;\n case \"next_7_days\":\n strStartDay = moment(now).format(\"YYYY-MM-DD\");\n strEndDay = moment(next_7_days).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_next_7_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n break;\n case \"next_30_days\":\n strStartDay = moment(now).format(\"YYYY-MM-DD\");\n strEndDay = moment(next_30_days).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_next_30_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n break;\n case \"next_60_days\":\n strStartDay = moment(now).format(\"YYYY-MM-DD\");\n strEndDay = moment(next_60_days).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_next_60_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n break;\n case \"next_90_days\":\n strStartDay = moment(now).format(\"YYYY-MM-DD\");\n strEndDay = moment(next_90_days).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_next_90_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n break;\n case \"next_120_days\":\n strStartDay = moment(now).format(\"YYYY-MM-DD\");\n strEndDay = moment(next_120_days).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_next_120_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n }\n values = [startValue, endValue];\n if (field_type === \"datetime\") {\n _.forEach(values, function(fv) {\n if (fv) {\n return fv.setHours(fv.getHours() + fv.getTimezoneOffset() / 60);\n }\n });\n }\n return {\n label: label,\n key: key,\n values: values\n };\n};\n\nCreator.getFieldDefaultOperation = function(field_type) {\n if (field_type && Creator.checkFieldTypeSupportBetweenQuery(field_type)) {\n return 'between';\n } else if ([\"textarea\", \"text\", \"code\"].includes(field_type)) {\n return 'contains';\n } else {\n return \"=\";\n }\n};\n\nCreator.getFieldOperation = function(field_type) {\n var operations, optionals;\n optionals = {\n equal: {\n label: t(\"creator_filter_operation_equal\"),\n value: \"=\"\n },\n unequal: {\n label: t(\"creator_filter_operation_unequal\"),\n value: \"<>\"\n },\n less_than: {\n label: t(\"creator_filter_operation_less_than\"),\n value: \"<\"\n },\n greater_than: {\n label: t(\"creator_filter_operation_greater_than\"),\n value: \">\"\n },\n less_or_equal: {\n label: t(\"creator_filter_operation_less_or_equal\"),\n value: \"<=\"\n },\n greater_or_equal: {\n label: t(\"creator_filter_operation_greater_or_equal\"),\n value: \">=\"\n },\n contains: {\n label: t(\"creator_filter_operation_contains\"),\n value: \"contains\"\n },\n not_contain: {\n label: t(\"creator_filter_operation_does_not_contain\"),\n value: \"notcontains\"\n },\n starts_with: {\n label: t(\"creator_filter_operation_starts_with\"),\n value: \"startswith\"\n },\n between: {\n label: t(\"creator_filter_operation_between\"),\n value: \"between\"\n }\n };\n if (field_type === void 0) {\n return _.values(optionals);\n }\n operations = [];\n if (Creator.checkFieldTypeSupportBetweenQuery(field_type)) {\n operations.push(optionals.between);\n Creator.pushBetweenBuiltinOptionals(field_type, operations);\n } else if (field_type === \"text\" || field_type === \"textarea\" || field_type === \"html\" || field_type === \"code\") {\n operations.push(optionals.contains);\n } else if (field_type === \"lookup\" || field_type === \"master_detail\" || field_type === \"select\") {\n operations.push(optionals.equal, optionals.unequal);\n } else if (field_type === \"currency\" || field_type === \"number\") {\n operations.push(optionals.equal, optionals.unequal, optionals.less_than, optionals.greater_than, optionals.less_or_equal, optionals.greater_or_equal);\n } else if (field_type === \"boolean\") {\n operations.push(optionals.equal, optionals.unequal);\n } else if (field_type === \"checkbox\") {\n operations.push(optionals.equal, optionals.unequal);\n } else if (field_type === \"[text]\") {\n operations.push(optionals.equal, optionals.unequal);\n } else {\n operations.push(optionals.equal, optionals.unequal);\n }\n return operations;\n};\n\n\n/*\n 先按照有排序号的小的在前,大的在后\n 再将没有排序号的显示在\n */\n\nCreator.getObjectFieldsName = function(object_name) {\n var fields, fieldsArr, fieldsName, ref;\n fields = (ref = Creator.getObject(object_name)) != null ? ref.fields : void 0;\n fieldsArr = [];\n _.each(fields, function(field) {\n return fieldsArr.push({\n name: field.name,\n sort_no: field.sort_no\n });\n });\n fieldsName = [];\n _.each(_.sortBy(fieldsArr, \"sort_no\"), function(field) {\n return fieldsName.push(field.name);\n });\n return fieldsName;\n};\n","Creator._trigger_hooks = {}\n\ninitTrigger = (object_name, trigger)->\n\ttry\n\t\tcollection = Creator.getCollection(object_name)\n\t\tif !trigger.todo\n\t\t\treturn\n\t\ttodoWrapper = ()->\n\t\t\t this.object_name = object_name\n\t\t\t return trigger.todo.apply(this, arguments)\n\t\tif trigger.when == \"before.insert\"\n\t\t\t return collection?.before?.insert(todoWrapper)\n\t\t else if trigger.when == \"before.update\"\n\t\t\t return collection?.before?.update(todoWrapper)\n\t\t else if trigger.when == \"before.remove\"\n\t\t\t return collection?.before?.remove(todoWrapper)\n\t\t else if trigger.when == \"after.insert\"\n\t\t\t return collection?.after?.insert(todoWrapper)\n\t\t else if trigger.when == \"after.update\"\n\t\t\t return collection?.after?.update(todoWrapper)\n\t\t else if trigger.when == \"after.remove\"\n\t\t\t return collection?.after?.remove(todoWrapper)\n\tcatch error\n\t\tconsole.error('initTrigger error', error)\n\ncleanTrigger = (object_name)->\n\t###\n \t由于collection-hooks package 的remove函数是使用下标删除对象的,所以此处反转hooks集合后,再删除\n \t因为一个数组元素删除后,其他元素的下标会发生变化\n\t###\n #TODO 由于collection-hooks package 的remove函数bug\n\tCreator._trigger_hooks[object_name]?.reverse().forEach (_hook)->\n\t\t_hook.remove()\n\nCreator.initTriggers = (object_name)->\n#\tconsole.log('Creator.initTriggers object_name', object_name)\n\tobj = Creator.getObject(object_name)\n\n\tcleanTrigger(object_name)\n\n\tCreator._trigger_hooks[object_name] = []\n\n\t_.each obj.triggers, (trigger, trigger_name)->\n\t\tif Meteor.isServer and trigger.on == \"server\" and trigger.todo and trigger.when\n\t\t\t_trigger_hook = initTrigger object_name, trigger\n\t\t\tif _trigger_hook\n\t\t\t\tCreator._trigger_hooks[object_name].push(_trigger_hook)\n\t\tif Meteor.isClient and trigger.on == \"client\" and trigger.todo and trigger.when\n\t\t\t_trigger_hook = initTrigger object_name, trigger\n\t\t\tCreator._trigger_hooks[object_name].push(_trigger_hook)","var cleanTrigger, initTrigger;\n\nCreator._trigger_hooks = {};\n\ninitTrigger = function(object_name, trigger) {\n var collection, error, ref, ref1, ref2, ref3, ref4, ref5, todoWrapper;\n try {\n collection = Creator.getCollection(object_name);\n if (!trigger.todo) {\n return;\n }\n todoWrapper = function() {\n this.object_name = object_name;\n return trigger.todo.apply(this, arguments);\n };\n if (trigger.when === \"before.insert\") {\n return collection != null ? (ref = collection.before) != null ? ref.insert(todoWrapper) : void 0 : void 0;\n } else if (trigger.when === \"before.update\") {\n return collection != null ? (ref1 = collection.before) != null ? ref1.update(todoWrapper) : void 0 : void 0;\n } else if (trigger.when === \"before.remove\") {\n return collection != null ? (ref2 = collection.before) != null ? ref2.remove(todoWrapper) : void 0 : void 0;\n } else if (trigger.when === \"after.insert\") {\n return collection != null ? (ref3 = collection.after) != null ? ref3.insert(todoWrapper) : void 0 : void 0;\n } else if (trigger.when === \"after.update\") {\n return collection != null ? (ref4 = collection.after) != null ? ref4.update(todoWrapper) : void 0 : void 0;\n } else if (trigger.when === \"after.remove\") {\n return collection != null ? (ref5 = collection.after) != null ? ref5.remove(todoWrapper) : void 0 : void 0;\n }\n } catch (error1) {\n error = error1;\n return console.error('initTrigger error', error);\n }\n};\n\ncleanTrigger = function(object_name) {\n\n /*\n \t由于collection-hooks package 的remove函数是使用下标删除对象的,所以此处反转hooks集合后,再删除\n \t因为一个数组元素删除后,其他元素的下标会发生变化\n */\n var ref;\n return (ref = Creator._trigger_hooks[object_name]) != null ? ref.reverse().forEach(function(_hook) {\n return _hook.remove();\n }) : void 0;\n};\n\nCreator.initTriggers = function(object_name) {\n var obj;\n obj = Creator.getObject(object_name);\n cleanTrigger(object_name);\n Creator._trigger_hooks[object_name] = [];\n return _.each(obj.triggers, function(trigger, trigger_name) {\n var _trigger_hook;\n if (Meteor.isServer && trigger.on === \"server\" && trigger.todo && trigger.when) {\n _trigger_hook = initTrigger(object_name, trigger);\n if (_trigger_hook) {\n Creator._trigger_hooks[object_name].push(_trigger_hook);\n }\n }\n if (Meteor.isClient && trigger.on === \"client\" && trigger.todo && trigger.when) {\n _trigger_hook = initTrigger(object_name, trigger);\n return Creator._trigger_hooks[object_name].push(_trigger_hook);\n }\n });\n};\n","clone = require('clone')\n\nbaseBooleanPermissionPropNames = [\"allowCreate\", \"allowDelete\", \"allowEdit\", \"allowRead\", \"modifyAllRecords\", \"viewAllRecords\", \"modifyCompanyRecords\", \"viewCompanyRecords\", \n\t\"allowReadFiles\", \"allowEditFiles\", \"allowCreateFiles\", \"allowDeleteFiles\", \"viewAllFiles\", \"modifyAllFiles\"] \notherPermissionPropNames = [\"disabled_list_views\", \"disabled_actions\", \"unreadable_fields\", \"uneditable_fields\", \"unrelated_objects\", \"uneditable_related_list\"]\npermissionPropNames = _.union baseBooleanPermissionPropNames, otherPermissionPropNames\n\nCreator.getPermissions = (object_name, spaceId, userId)->\n\tif Meteor.isClient\n\t\tif !object_name\n\t\t\tobject_name = Session.get(\"object_name\")\n\t\tobj = Creator.getObject(object_name)\n\t\tif !obj\n\t\t\treturn\n\t\treturn obj.permissions.get()\n\telse if Meteor.isServer\n\t\tCreator.getObjectPermissions(spaceId, userId, object_name)\n\nCreator.getRecordPermissions = (object_name, record, userId, spaceId)->\n\tif !object_name and Meteor.isClient\n\t\tobject_name = Session.get(\"object_name\")\n\n\tif !spaceId and Meteor.isClient\n\t\tspaceId = Session.get(\"spaceId\")\n\t\n\t# 附件权限不再与其父记录编辑配置关联\n\t# if record and object_name == \"cms_files\" and Meteor.isClient\n\t# \t# 如果是cms_files附件,则权限取其父记录权限\n\t# \tif object_name == Session.get('object_name')\n\t# \t\t# 当前处于cms_files附件详细界面\n\t# \t\tobject_name = record.parent['reference_to._o'];\n\t# \t\trecord_id = record.parent._id;\n\t# \telse \n\t# \t\t# 当前处于cms_files附件的父记录界面\n\t# \t\tobject_name = Session.get('object_name');\n\t# \t\trecord_id = Session.get(\"record_id\");\n\t# \tobject_fields_keys = _.keys(Creator.getObject(object_name, spaceId)?.fields or {}) || [];\n\t# \tselect = _.intersection(object_fields_keys, ['owner', 'company_id', 'company_ids', 'locked']) || [];\n\t# \tif select.length > 0\n\t# \t\trecord = Creator.getObjectRecord(object_name, record_id, select.join(','));\n\t# \telse\n\t# \t\trecord = null;\n\n\tpermissions = _.clone(Creator.getPermissions(object_name, spaceId, userId))\n\n\tif record\n\t\tif !_.isEmpty(record.record_permissions)\n\t\t\treturn record.record_permissions\n\n\t\tisOwner = record.owner == userId || record.owner?._id == userId\n\n\t\tif object_name == \"cms_files\"\n\t\t\t# 附件的查看所有修改所有权限与附件对象的viewAllRecords、modifyAllRecords无关,只与其主表记录的viewAllFiles和modifyAllFiles有关\n\t\t\t# 如果是cms_files附件,则权限需要额外考虑其父对象上关于附件的权限配置\n\t\t\tmasterObjectName = record.parent['reference_to._o'];\n\t\t\tmasterRecordPerm = Creator.getPermissions(masterObjectName, spaceId, userId)\n\t\t\tpermissions.allowCreate = permissions.allowCreate && masterRecordPerm.allowCreateFiles\n\t\t\tpermissions.allowEdit = permissions.allowEdit && masterRecordPerm.allowEditFiles\n\t\t\tpermissions.allowDelete = permissions.allowDelete && masterRecordPerm.allowDeleteFiles\n\t\t\tif !masterRecordPerm.modifyAllFiles and !isOwner\n\t\t\t\tpermissions.allowEdit = false\n\t\t\t\tpermissions.allowDelete = false\n\t\t\tpermissions.allowRead = permissions.allowRead && masterRecordPerm.allowReadFiles\n\t\t\tif !masterRecordPerm.viewAllFiles and !isOwner\n\t\t\t\tpermissions.allowRead = false\n\t\telse\n\t\t\tif Meteor.isClient\n\t\t\t\tuser_company_ids = Steedos.getUserCompanyIds()\n\t\t\telse\n\t\t\t\tuser_company_ids = Creator.getUserCompanyIds(userId, spaceId)\n\t\t\trecord_company_id = record?.company_id\n\t\t\tif record_company_id and _.isObject(record_company_id) and record_company_id._id\n\t\t\t\t# 因record_company_id是lookup类型,有可能dx控件会把它映射转为对应的object,所以这里取出其_id值\n\t\t\t\trecord_company_id = record_company_id._id\n\t\t\trecord_company_ids = record?.company_ids\n\t\t\tif record_company_ids and record_company_ids.length and _.isObject(record_company_ids[0])\n\t\t\t\t# 因record_company_ids是lookup类型,有可能dx控件会把它映射转为对应的[object],所以这里取出其_id值\n\t\t\t\trecord_company_ids = record_company_ids.map((n)-> n._id)\n\t\t\trecord_company_ids = _.union(record_company_ids, [record_company_id])\n\t\t\tif !permissions.modifyAllRecords and !isOwner and !permissions.modifyCompanyRecords\n\t\t\t\tpermissions.allowEdit = false\n\t\t\t\tpermissions.allowDelete = false\n\t\t\telse if !permissions.modifyAllRecords and permissions.modifyCompanyRecords\n\t\t\t\tif record_company_ids and record_company_ids.length\n\t\t\t\t\tif user_company_ids and user_company_ids.length\n\t\t\t\t\t\tif !_.intersection(user_company_ids, record_company_ids).length\n\t\t\t\t\t\t\t# 记录的company_id/company_ids属性不在当前用户user_company_ids范围内时,认为无权修改\n\t\t\t\t\t\t\tpermissions.allowEdit = false\n\t\t\t\t\t\t\tpermissions.allowDelete = false\n\t\t\t\t\telse\n\t\t\t\t\t\t# 记录有company_id/company_ids属性,但是当前用户user_company_ids为空时,认为无权修改\n\t\t\t\t\t\tpermissions.allowEdit = false\n\t\t\t\t\t\tpermissions.allowDelete = false\n\t\t\t\n\t\t\tif record.locked and !permissions.modifyAllRecords\n\t\t\t\tpermissions.allowEdit = false\n\t\t\t\tpermissions.allowDelete = false\n\n\t\t\tif !permissions.viewAllRecords and !isOwner and !permissions.viewCompanyRecords\n\t\t\t\tpermissions.allowRead = false\n\t\t\telse if !permissions.viewAllRecords and permissions.viewCompanyRecords\n\t\t\t\tif record_company_ids and record_company_ids.length\n\t\t\t\t\tif user_company_ids and user_company_ids.length\n\t\t\t\t\t\tif !_.intersection(user_company_ids, record_company_ids).length\n\t\t\t\t\t\t\t# 记录的company_id/company_ids属性不在当前用户user_company_ids范围内时,认为无权查看\n\t\t\t\t\t\t\tpermissions.allowRead = false\n\t\t\t\t\telse\n\t\t\t\t\t\t# 记录有company_id属性,但是当前用户user_company_ids为空时,认为无权查看\n\t\t\t\t\t\tpermissions.allowRead = false\n\t\n\treturn permissions\n\n\n# currentObjectName:当前主对象\n# relatedListItem:Creator.getRelatedList(Session.get(\"object_name\"), Session.get(\"record_id\"))中取related_object_name对应的值\n# currentRecord当前主对象的详细记录\nif Meteor.isClient\n\tCreator.getRecordRelatedListPermissions = (currentObjectName, relatedListItem, currentRecord, userId, spaceId)->\n\t\tif !currentObjectName and Meteor.isClient\n\t\t\tcurrentObjectName = Session.get(\"object_name\")\n\n\t\tif !relatedListItem\n\t\t\tconsole.error(\"relatedListItem must not be empty for the function Creator.getRecordRelatedListPermissions\");\n\t\t\treturn {}\n\n\t\tif !currentRecord and Meteor.isClient\n\t\t\tcurrentRecord = Creator.getObjectRecord()\n\n\t\tif !userId and Meteor.isClient\n\t\t\tuserId = Meteor.userId()\n\n\t\tif !spaceId and Meteor.isClient\n\t\t\tspaceId = Session.get(\"spaceId\")\n\n\t\tmasterRecordPerm = Creator.getRecordPermissions(currentObjectName, currentRecord, userId, spaceId)\n\t\trelatedObjectPermissions = Creator.getPermissions(relatedListItem.object_name)\n\t\tresult = _.clone relatedObjectPermissions\n\n\t\tif relatedListItem.is_file\n\t\t\tresult.allowCreate = relatedObjectPermissions.allowCreate && masterRecordPerm.allowCreateFiles\n\t\t\tresult.allowEdit = relatedObjectPermissions.allowEdit && masterRecordPerm.allowEditFiles\n\t\telse\n\t\t\twrite_requires_master_read = relatedListItem.write_requires_master_read || false\n\t\t\tmasterAllow = false\n\t\t\tif write_requires_master_read == true\n\t\t\t\tmasterAllow = masterRecordPerm.allowRead\n\t\t\telse if write_requires_master_read == false\n\t\t\t\tmasterAllow = masterRecordPerm.allowEdit\n\n\t\t\tuneditable_related_list = Creator.getRecordSafeRelatedList(currentRecord, currentObjectName)\n\t\t\tisRelateObjectUneditable = uneditable_related_list.indexOf(relatedListItem.object_name) > -1\n\n\t\t\tresult.allowCreate = masterAllow && relatedObjectPermissions.allowCreate && !isRelateObjectUneditable\n\t\t\tresult.allowEdit = masterAllow && relatedObjectPermissions.allowEdit && !isRelateObjectUneditable\n\t\treturn result\n\nif Meteor.isServer\n\n\tCreator.getAllPermissions = (spaceId, userId) ->\n\t\tpermissions =\n\t\t\tobjects: {}\n\t\t\tassigned_apps: []\n\t\t###\n\t\t权限集说明:\n\t\t内置权限集-admin,user,member,guest,workflow_admin,organization_admin\n\t\t自定义权限集-数据库中新建的除内置权限集以外的其他权限集\n\t\t特定用户集合权限集(即users属性不可配置)-admin,user,member,guest\n\t\t可配置用户集合权限集(即users属性可配置)-workflow_admin,organization_admin以及自定义权限集\n\t\t###\n\n\t\tisSpaceAdmin = false\n\t\tspaceUser = null\n\t\tif userId\n\t\t\tisSpaceAdmin = Creator.isSpaceAdmin(spaceId, userId)\n\t\t\tspaceUser = Creator.getCollection(\"space_users\").findOne({ space: spaceId, user: userId }, { fields: { profile: 1 } })\n\n\t\tpsetsAdmin = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'admin'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tpsetsUser = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'user'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tpsetsMember = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'member'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tpsetsGuest = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'guest'}, {fields:{_id:1, assigned_apps:1}}) || null\n\n\t\tpsetsSupplier = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'supplier'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tpsetsCustomer = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'customer'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tif spaceUser && spaceUser.profile\n\t\t\tpsetsCurrent = Creator.getCollection(\"permission_set\").find({space: spaceId, $or: [{users: userId}, {name: spaceUser.profile}]}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\telse\n\t\t\tpsetsCurrent = Creator.getCollection(\"permission_set\").find({users: userId, space: spaceId}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\n\t\tpsetsAdmin_pos = null\n\t\tpsetsUser_pos = null\n\t\tpsetsMember_pos = null\n\t\tpsetsGuest_pos = null\n\t\tpsetsCurrent_pos = null\n\t\tpsetsSupplier_pos = null\n\t\tpsetsCustomer_pos = null\n\n\t\tif psetsAdmin?._id\n\t\t\tpsetsAdmin_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsAdmin._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsUser?._id\n\t\t\tpsetsUser_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsUser._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsMember?._id\n\t\t\tpsetsMember_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsMember._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsGuest?._id\n\t\t\tpsetsGuest_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsGuest._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsSupplier?._id\n\t\t\tpsetsSupplier_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsSupplier._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsCustomer?._id\n\t\t\tpsetsCustomer_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsCustomer._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\n\t\tif psetsCurrent.length > 0\n\t\t\tset_ids = _.pluck psetsCurrent, \"_id\"\n\t\t\tpsetsCurrent_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: {$in: set_ids}}).fetch()\n\t\t\tpsetsCurrentNames = _.pluck psetsCurrent, \"name\"\n\t\tpsets = {\n\t\t\tpsetsAdmin, \n\t\t\tpsetsUser, \n\t\t\tpsetsCurrent, \n\t\t\tpsetsMember, \n\t\t\tpsetsGuest,\n\t\t\tpsetsSupplier,\n\t\t\tpsetsCustomer,\n\t\t\tisSpaceAdmin,\n\t\t\tspaceUser, \n\t\t\tpsetsAdmin_pos, \n\t\t\tpsetsUser_pos, \n\t\t\tpsetsMember_pos, \n\t\t\tpsetsGuest_pos,\n\t\t\tpsetsSupplier_pos,\n\t\t\tpsetsCustomer_pos,\n\t\t\tpsetsCurrent_pos\n\t\t}\n\t\tpermissions.assigned_apps = Creator.getAssignedApps.bind(psets)(spaceId, userId)\n\t\tpermissions.assigned_menus = Creator.getAssignedMenus.bind(psets)(spaceId, userId)\n\t\tpermissions.user_permission_sets = psetsCurrentNames\n\t\t_i = 0\n\t\t_.each Creator.objectsByName, (object, object_name)->\n\t\t\t_i++\n\t\t\tif !_.has(object, 'space') || !object.space || object.space == spaceId\n\t\t\t\tif !_.has(object, 'in_development') || object.in_development == '0' || (object.in_development != '0' && isSpaceAdmin)\n\t\t\t\t\tpermissions.objects[object_name] = Creator.convertObject(clone(Creator.Objects[object_name]), spaceId)\n\t\t\t\t\tpermissions.objects[object_name][\"permissions\"] = Creator.getObjectPermissions.bind(psets)(spaceId, userId, object_name)\n\t\treturn permissions\n\n\tunionPlus = (array, other) ->\n\t\tif !array and !other\n\t\t\treturn undefined\n\t\tif !array\n\t\t\tarray = []\n\t\tif !other\n\t\t\tother = []\n\t\treturn _.union(array, other)\n\n\tintersectionPlus = (array, other) ->\n\t\tif !array and !other\n\t\t\treturn undefined\n\t\tif !array\n\t\t\tarray = []\n\t\tif !other\n\t\t\tother = []\n\t\treturn _.intersection(array, other)\n\n\textendPermissionProps = (target, props) ->\n\t\tpropNames = permissionPropNames\n\t\tfilesProNames = \n\t\tif props\n\t\t\t_.each propNames, (propName) ->\n\t\t\t\ttarget[propName] = props[propName]\n\n\t\t\t# target.allowCreate = props.allowCreate\n\t\t\t# target.allowDelete = props.allowDelete\n\t\t\t# target.allowEdit = props.allowEdit\n\t\t\t# target.allowRead = props.allowRead\n\t\t\t# target.modifyAllRecords = props.modifyAllRecords\n\t\t\t# target.viewAllRecords = props.viewAllRecords\n\t\t\t# target.modifyCompanyRecords = props.modifyCompanyRecords\n\t\t\t# target.viewCompanyRecords = props.viewCompanyRecords\n\t\t\t# target.disabled_list_views = props.disabled_list_views\n\t\t\t# target.disabled_actions = props.disabled_actions\n\t\t\t# target.unreadable_fields = props.unreadable_fields\n\t\t\t# target.uneditable_fields = props.uneditable_fields\n\t\t\t# target.unrelated_objects = props.unrelated_objects\n\t\t\t# target.uneditable_related_list = props.uneditable_related_list\n\n\toverlayBaseBooleanPermissionProps = (target, props) ->\n\t\tpropNames = baseBooleanPermissionPropNames\n\t\t_.each propNames, (propName) ->\n\t\t\tif props[propName]\n\t\t\t\ttarget[propName] = true\n\t\t\n\t\t# if po.allowRead\n\t\t# \tpermissions.allowRead = true\n\t\t# if po.allowCreate\n\t\t# \tpermissions.allowCreate = true\n\t\t# if po.allowEdit\n\t\t# \tpermissions.allowEdit = true\n\t\t# if po.allowDelete\n\t\t# \tpermissions.allowDelete = true\n\t\t# if po.modifyAllRecords\n\t\t# \tpermissions.modifyAllRecords = true\n\t\t# if po.viewAllRecords\n\t\t# \tpermissions.viewAllRecords = true\n\t\t# if po.modifyCompanyRecords\n\t\t# \tpermissions.modifyCompanyRecords = true\n\t\t# if po.viewCompanyRecords\n\t\t# \tpermissions.viewCompanyRecords = true\n\n\n\tCreator.getAssignedApps = (spaceId, userId)->\n\t\tpsetsAdmin = this.psetsAdmin || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'admin'}, {fields:{_id:1, assigned_apps:1}})\n\t\tpsetsUser = this.psetsUser || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'user'}, {fields:{_id:1, assigned_apps:1}})\n\t\tpsetsSupplier = this.psetsMember || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'supplier'}, {fields:{_id:1, assigned_apps:1}})\n\t\tpsetsCustomer = this.psetsGuest || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'customer'}, {fields:{_id:1, assigned_apps:1}})\n\t\t# psetsMember = this.psetsMember || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'member'}, {fields:{_id:1, assigned_apps:1}})\n\t\t# psetsGuest = this.psetsGuest || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'guest'}, {fields:{_id:1, assigned_apps:1}})\n\t\tspaceUser = null;\n\t\tif userId\n\t\t\tspaceUser = Creator.getCollection(\"space_users\").findOne({ space: spaceId, user: userId }, { fields: { profile: 1 } })\n\t\tif spaceUser && spaceUser.profile\n\t\t\tpsets = Creator.getCollection(\"permission_set\").find({space: spaceId, $or: [{users: userId}, {name: spaceUser.profile}]}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\telse\n\t\t\tpsets = Creator.getCollection(\"permission_set\").find({users: userId, space: spaceId}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\tisSpaceAdmin = if _.isBoolean(this.isSpaceAdmin) then this.isSpaceAdmin else Creator.isSpaceAdmin(spaceId, userId)\n\t\tapps = []\n\t\tif isSpaceAdmin\n\t\t\treturn []\n\t\telse\n\t\t\tuserProfile = Creator.getCollection(\"space_users\").findOne({space: spaceId, user: userId}, {fields: {profile: 1}})?.profile\n\t\t\tpsetBase = psetsUser\n\t\t\tif userProfile\n\t\t\t\tif userProfile == 'supplier'\n\t\t\t\t\tpsetBase = psetsSupplier\n\t\t\t\telse if userProfile == 'customer'\n\t\t\t\t\tpsetBase = psetsCustomer\n\t\t\tif psetBase?.assigned_apps?.length\n\t\t\t\tapps = _.union apps, psetBase.assigned_apps\n\t\t\telse\n\t\t\t\t# user权限集中的assigned_apps表示所有用户具有的apps权限,为空则表示有所有apps权限,不需要作权限判断了\n\t\t\t\treturn []\n\t\t\t_.each psets, (pset)->\n\t\t\t\tif !pset.assigned_apps\n\t\t\t\t\treturn\n\t\t\t\tif pset.name == \"admin\" || pset.name == \"user\" || pset.name == 'supplier' || pset.name == 'customer'\n\t\t\t\t\t# 这里之所以要排除admin/user,是因为这两个权限集是所有权限集中users属性无效的权限集,特指工作区管理员和所有用户\n\t\t\t\t\treturn\n\t\t\t\tapps = _.union apps, pset.assigned_apps\n\t\t\treturn _.without(_.uniq(apps),undefined,null)\n\n\tCreator.getAssignedMenus = (spaceId, userId)->\n\t\tpsets = this.psetsCurrent || Creator.getCollection(\"permission_set\").find({users: userId, space: spaceId}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\tisSpaceAdmin = if _.isBoolean(this.isSpaceAdmin) then this.isSpaceAdmin else Creator.isSpaceAdmin(spaceId, userId)\n\t\tadminMenus = Creator.Apps.admin?.admin_menus\n\t\t# 如果没有admin菜单说明不需要相关功能,直接返回空\n\t\tunless adminMenus\n\t\t\treturn []\n\t\taboutMenu = adminMenus.find (n) ->\n\t\t\tn._id == 'about'\n\t\tadminMenus = adminMenus.filter (n) ->\n\t\t\tn._id != 'about'\n\t\totherMenuApps = _.sortBy _.filter(_.values(Creator.Apps), (n) ->\n\t\t\treturn n.admin_menus and n._id != 'admin'\n\t\t), 'sort'\n\t\totherMenus = _.flatten(_.pluck(otherMenuApps, \"admin_menus\"))\n\t\t# 菜单有三部分组成,设置APP菜单、其他APP菜单以及about菜单\n\t\tallMenus = _.union(adminMenus, otherMenus, [aboutMenu])\n\t\tif isSpaceAdmin\n\t\t\t# 工作区管理员有全部菜单功能\n\t\t\tresult = allMenus\n\t\telse\n\t\t\tuserProfile = Creator.getCollection(\"space_users\").findOne({space: spaceId, user: userId}, {fields: {profile: 1}})?.profile || 'user'\n\t\t\tcurrentPsetNames = psets.map (n) ->\n\t\t\t\treturn n.name\n\t\t\tmenus = allMenus.filter (menu)->\n\t\t\t\tpsetsMenu = menu.permission_sets\n\t\t\t\t# 如果普通用户有权限,则直接返回true\n\t\t\t\tif psetsMenu && psetsMenu.indexOf(userProfile) > -1\n\t\t\t\t\treturn true\n\t\t\t\t# 否则取当前用户的权限集与menu菜单要求的权限集对比,如果交集大于1个则返回true\n\t\t\t\treturn _.intersection(currentPsetNames, psetsMenu).length\n\t\t\tresult = menus\n\t\t\n\t\treturn _.sortBy(result,\"sort\")\n\n\tfindOne_permission_object = (permission_objects, object_name, permission_set_id)->\n\n\t\tif _.isNull(permission_objects)\n\t\t\treturn null\n\t\tif _.isArray(permission_objects)\n\t\t\treturn _.find permission_objects, (po)->\n\t\t\t\t\treturn po.object_name == object_name\n\t\treturn Creator.getCollection(\"permission_objects\").findOne({object_name: object_name, permission_set_id: permission_set_id})\n\n\tfind_permission_object = (permission_objects, object_name, permission_set_ids)->\n\t\tif _.isNull(permission_objects)\n\t\t\treturn null\n\t\tif _.isArray(permission_objects)\n\t\t\treturn _.filter permission_objects, (po)->\n\t\t\t\treturn po.object_name == object_name\n\t\tCreator.getCollection(\"permission_objects\").find({object_name: object_name, permission_set_id: {$in: permission_set_ids}}).fetch()\n\n\tunionPermissionObjects = (pos, object, psets)->\n\t\t# 把db及yml中的permission_objects合并,优先取db中的\n\t\tresult = []\n\t\t_.each object.permission_set, (ops, ops_key)->\n\t\t\t# 把yml中除了特定用户集合权限集\"admin\", \"user\", \"member\", \"guest\"外的其他对象权限先存入result\n\t\t\t# if [\"admin\", \"user\", \"member\", \"guest\", \"workflow_admin\", \"organization_admin\"].indexOf(ops_key) < 0\n\t\t\tif [\"admin\", \"user\", \"member\", \"guest\"].indexOf(ops_key) < 0\n\t\t\t\tcurrentPset = psets.find (pset)-> return pset.name == ops_key\n\t\t\t\tif currentPset\n\t\t\t\t\ttempOps = _.clone(ops) || {}\n\t\t\t\t\ttempOps.permission_set_id = currentPset._id\n\t\t\t\t\ttempOps.object_name = object.object_name\n\t\t\t\t\tresult.push tempOps\n\t\tif result.length\n\t\t\tpos.forEach (po)->\n\t\t\t\trepeatIndex = 0\n\t\t\t\trepeatPo = result.find((item, index)-> repeatIndex = index;return item.permission_set_id == po.permission_set_id)\n\t\t\t\t# 如果yml中已经存在po,则替换为数据库中的po,反之则把数据库中的po直接累加进去\n\t\t\t\tif repeatPo\n\t\t\t\t\tresult[repeatIndex] = po\n\t\t\t\telse\n\t\t\t\t\tresult.push po\n\t\t\treturn result\n\t\telse\n\t\t\treturn pos\n\n\tCreator.getObjectPermissions = (spaceId, userId, object_name)->\n\t\tpermissions = {}\n\t\tobject = Creator.getObject(object_name, spaceId)\n\n\t\tif spaceId is 'guest' || object_name == \"users\"\n\t\t\tpermissions = _.clone(object.permission_set.guest) || {}\n\t\t\tCreator.processPermissions permissions\n\t\t\treturn permissions\n\t\tpsetsAdmin = if _.isNull(this.psetsAdmin) or this.psetsAdmin then this.psetsAdmin else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'admin'}, {fields:{_id:1}})\n\t\tpsetsUser = if _.isNull(this.psetsUser) or this.psetsUser then this.psetsUser else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'user'}, {fields:{_id:1}})\n\t\tpsetsMember = if _.isNull(this.psetsMember) or this.psetsMember then this.psetsMember else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'member'}, {fields:{_id:1}})\n\t\tpsetsGuest = if _.isNull(this.psetsGuest) or this.psetsGuest then this.psetsGuest else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'guest'}, {fields:{_id:1}})\n\n\t\tpsetsSupplier = if _.isNull(this.psetsSupplier) or this.psetsSupplier then this.psetsSupplier else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'supplier'}, {fields:{_id:1}})\n\t\tpsetsCustomer = if _.isNull(this.psetsCustomer) or this.psetsCustomer then this.psetsCustomer else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'customer'}, {fields:{_id:1}})\n\t\tpsets = this.psetsCurrent;\n\t\tif !psets\n\t\t\tspaceUser = null;\n\t\t\tif userId\n\t\t\t\tspaceUser = Creator.getCollection(\"space_users\").findOne({ space: spaceId, user: userId }, { fields: { profile: 1 } })\n\t\t\tif spaceUser && spaceUser.profile\n\t\t\t\tpsets = Creator.getCollection(\"permission_set\").find({space: spaceId, $or: [{users: userId}, {name: spaceUser.profile}]}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\t\telse\n\t\t\t\tpsets = Creator.getCollection(\"permission_set\").find({users: userId, space: spaceId}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\tisSpaceAdmin = if _.isBoolean(this.isSpaceAdmin) then this.isSpaceAdmin else Creator.isSpaceAdmin(spaceId, userId)\n\n\t\tpsetsAdmin_pos = this.psetsAdmin_pos\n\t\tpsetsUser_pos = this.psetsUser_pos\n\t\tpsetsMember_pos = this.psetsMember_pos\n\t\tpsetsGuest_pos = this.psetsGuest_pos\n\n\t\tpsetsSupplier_pos = this.psetsSupplier_pos\n\t\tpsetsCustomer_pos = this.psetsCustomer_pos\n\n\t\tpsetsCurrent_pos = this.psetsCurrent_pos\n\n\t\topsetAdmin = _.clone(object.permission_set.admin) || {}\n\t\topsetUser = _.clone(object.permission_set.user) || {}\n\t\topsetMember = _.clone(object.permission_set.member) || {}\n\t\topsetGuest = _.clone(object.permission_set.guest) || {}\n\n\t\topsetSupplier = _.clone(object.permission_set.supplier) || {}\n\t\topsetCustomer = _.clone(object.permission_set.customer) || {}\n\n\t\t# sharedListViews = Creator.getCollection('object_listviews').find({space: spaceId, object_name: object_name, shared: true}, {fields:{_id:1}}).fetch()\n\t\t# sharedListViews = _.pluck(sharedListViews,\"_id\")\n\t\t# if sharedListViews.length\n\t\t# \tunless opsetAdmin.list_views\n\t\t# \t\topsetAdmin.list_views = []\n\t\t# \topsetAdmin.list_views = _.union opsetAdmin.list_views, sharedListViews\n\t\t# \tunless opsetUser.list_views\n\t\t# \t\topsetUser.list_views = []\n\t\t# \topsetUser.list_views = _.union opsetUser.list_views, sharedListViews\n\t\t# 数据库中如果配置了默认的admin/user权限集设置,应该覆盖代码中admin/user的权限集设置\n\t\tif psetsAdmin\n\t\t\tposAdmin = findOne_permission_object(psetsAdmin_pos, object_name, psetsAdmin._id)\n\t\t\textendPermissionProps opsetAdmin, posAdmin\n\t\tif psetsUser\n\t\t\tposUser = findOne_permission_object(psetsUser_pos, object_name, psetsUser._id)\n\t\t\textendPermissionProps opsetUser, posUser\n\t\tif psetsMember\n\t\t\tposMember = findOne_permission_object(psetsMember_pos, object_name, psetsMember._id)\n\t\t\textendPermissionProps opsetMember, posMember\n\t\tif psetsGuest\n\t\t\tposGuest = findOne_permission_object(psetsGuest_pos, object_name, psetsGuest._id)\n\t\t\textendPermissionProps opsetGuest, posGuest\n\t\tif psetsSupplier\n\t\t\tposSupplier = findOne_permission_object(psetsSupplier_pos, object_name, psetsSupplier._id);\n\t\t\textendPermissionProps opsetSupplier, posSupplier\n\t\tif psetsCustomer\n\t\t\tposCustomer = findOne_permission_object(psetsCustomer_pos, object_name, psetsCustomer._id);\n\t\t\textendPermissionProps opsetCustomer, posCustomer\n\n\t\tif !userId\n\t\t\tpermissions = opsetAdmin\n\t\telse\n\t\t\tif isSpaceAdmin\n\t\t\t\tpermissions = opsetAdmin\n\t\t\telse\n\t\t\t\tif spaceId is 'common'\n\t\t\t\t\tpermissions = opsetUser\n\t\t\t\telse\n\t\t\t\t\tspaceUser = if _.isNull(this.spaceUser) or this.spaceUser then this.spaceUser else Creator.getCollection(\"space_users\").findOne({ space: spaceId, user: userId }, { fields: { profile: 1 } })\n\t\t\t\t\tif spaceUser\n\t\t\t\t\t\tprof = spaceUser.profile\n\t\t\t\t\t\tif prof\n\t\t\t\t\t\t\tif prof is 'user'\n\t\t\t\t\t\t\t\tpermissions = opsetUser\n\t\t\t\t\t\t\telse if prof is 'member'\n\t\t\t\t\t\t\t\tpermissions = opsetMember\n\t\t\t\t\t\t\telse if prof is 'guest'\n\t\t\t\t\t\t\t\tpermissions = opsetGuest\n\t\t\t\t\t\t\telse if prof is 'supplier'\n\t\t\t\t\t\t\t\tpermissions = opsetSupplier\n\t\t\t\t\t\t\telse if prof is 'customer'\n\t\t\t\t\t\t\t\tpermissions = opsetCustomer\n\t\t\t\t\t\telse # 没有profile则认为是user权限\n\t\t\t\t\t\t\tpermissions = opsetUser\n\t\t\t\t\telse\n\t\t\t\t\t\tpermissions = opsetGuest\n\t\tif psets.length > 0\n\t\t\tset_ids = _.pluck psets, \"_id\"\n\t\t\tpos = find_permission_object(psetsCurrent_pos, object_name, set_ids)\n\t\t\tpos = unionPermissionObjects(pos, object, psets)\n\t\t\t_.each pos, (po)->\n\t\t\t\tif po.permission_set_id == psetsAdmin?._id or \n\t\t\t\tpo.permission_set_id == psetsUser?._id or \n\t\t\t\tpo.permission_set_id == psetsMember?._id or \n\t\t\t\tpo.permission_set_id == psetsGuest?._id or\n\t\t\t\tpo.permission_set_id == psetsSupplier?._id or\n\t\t\t\tpo.permission_set_id == psetsCustomer?._id\n\t\t\t\t\t# 默认的admin/user权限值只实行上面的默认值覆盖,不做算法判断\n\t\t\t\t\treturn\n\t\t\t\tif _.isEmpty(permissions)\n\t\t\t\t\tpermissions = po\n\t\t\t\toverlayBaseBooleanPermissionProps permissions, po\n\n\t\t\t\tpermissions.disabled_list_views = intersectionPlus(permissions.disabled_list_views, po.disabled_list_views)\n\t\t\t\tpermissions.disabled_actions = intersectionPlus(permissions.disabled_actions, po.disabled_actions)\n\t\t\t\tpermissions.unreadable_fields = intersectionPlus(permissions.unreadable_fields, po.unreadable_fields)\n\t\t\t\tpermissions.uneditable_fields = intersectionPlus(permissions.uneditable_fields, po.uneditable_fields)\n\t\t\t\tpermissions.unrelated_objects = intersectionPlus(permissions.unrelated_objects, po.unrelated_objects)\n\t\t\t\tpermissions.uneditable_related_list = intersectionPlus(permissions.uneditable_related_list, po.uneditable_related_list)\n\t\t\n\t\tif object.is_view\n\t\t\tpermissions.allowCreate = false\n\t\t\tpermissions.allowEdit = false\n\t\t\tpermissions.allowDelete = false\n\t\t\tpermissions.modifyAllRecords = false\n\t\t\tpermissions.modifyCompanyRecords = false\n\t\t\tpermissions.disabled_actions = []\n\t\tCreator.processPermissions permissions\n\n\t\tif object.permission_set.owner\n\t\t\tpermissions.owner = object.permission_set.owner\n\t\treturn permissions\n\n\n\t# Creator.initPermissions = (object_name) ->\n\n\t\t# # 应该把计算出来的\n\t\t# Creator.Collections[object_name].allow\n\t\t# \tinsert: (userId, doc) ->\n\t\t# \t\tif !userId\n\t\t# \t\t\treturn false\n\t\t# \t\tif !doc.space\n\t\t# \t\t\treturn false\n\t \t# \t\tpermissions = Creator.getObjectPermissions(doc.space, userId, object_name)\n\t\t# \t\tif !permissions.allowCreate\n\t\t# \t\t\treturn false\n\n\t\t# \t\treturn true\n\t\t# \tupdate: (userId, doc) ->\n\t\t# \t\tif !userId\n\t\t# \t\t\treturn false\n\t\t# \t\tif !doc.space\n\t\t# \t\t\treturn false\n\t\t# \t\tpermissions = Creator.getObjectPermissions(doc.space, userId, object_name)\n\t\t# \t\tif !permissions.allowEdit\n\t\t# \t\t\treturn false\n\t\t# \t\treturn true\n\t\t# \tremove: (userId, doc) ->\n\t\t# \t\tif !userId\n\t\t# \t\t\treturn false\n\t\t# \t\tif !doc.space\n\t\t# \t\t\treturn false\n\t\t# \t\tpermissions = Creator.getObjectPermissions(doc.space, userId, object_name)\n\t\t# \t\tif !permissions.allowDelete\n\t\t# \t\t\treturn false\n\t\t# \t\treturn true\n\n\tMeteor.methods\n\t\t# Calculate Permissions on Server\n\t\t\"creator.object_permissions\": (spaceId)->\n\t\t\treturn Creator.getAllPermissions(spaceId, this.userId)\n","var baseBooleanPermissionPropNames, clone, extendPermissionProps, findOne_permission_object, find_permission_object, intersectionPlus, otherPermissionPropNames, overlayBaseBooleanPermissionProps, permissionPropNames, unionPermissionObjects, unionPlus;\n\nclone = require('clone');\n\nbaseBooleanPermissionPropNames = [\"allowCreate\", \"allowDelete\", \"allowEdit\", \"allowRead\", \"modifyAllRecords\", \"viewAllRecords\", \"modifyCompanyRecords\", \"viewCompanyRecords\", \"allowReadFiles\", \"allowEditFiles\", \"allowCreateFiles\", \"allowDeleteFiles\", \"viewAllFiles\", \"modifyAllFiles\"];\n\notherPermissionPropNames = [\"disabled_list_views\", \"disabled_actions\", \"unreadable_fields\", \"uneditable_fields\", \"unrelated_objects\", \"uneditable_related_list\"];\n\npermissionPropNames = _.union(baseBooleanPermissionPropNames, otherPermissionPropNames);\n\nCreator.getPermissions = function(object_name, spaceId, userId) {\n var obj;\n if (Meteor.isClient) {\n if (!object_name) {\n object_name = Session.get(\"object_name\");\n }\n obj = Creator.getObject(object_name);\n if (!obj) {\n return;\n }\n return obj.permissions.get();\n } else if (Meteor.isServer) {\n return Creator.getObjectPermissions(spaceId, userId, object_name);\n }\n};\n\nCreator.getRecordPermissions = function(object_name, record, userId, spaceId) {\n var isOwner, masterObjectName, masterRecordPerm, permissions, record_company_id, record_company_ids, ref, user_company_ids;\n if (!object_name && Meteor.isClient) {\n object_name = Session.get(\"object_name\");\n }\n if (!spaceId && Meteor.isClient) {\n spaceId = Session.get(\"spaceId\");\n }\n permissions = _.clone(Creator.getPermissions(object_name, spaceId, userId));\n if (record) {\n if (!_.isEmpty(record.record_permissions)) {\n return record.record_permissions;\n }\n isOwner = record.owner === userId || ((ref = record.owner) != null ? ref._id : void 0) === userId;\n if (object_name === \"cms_files\") {\n masterObjectName = record.parent['reference_to._o'];\n masterRecordPerm = Creator.getPermissions(masterObjectName, spaceId, userId);\n permissions.allowCreate = permissions.allowCreate && masterRecordPerm.allowCreateFiles;\n permissions.allowEdit = permissions.allowEdit && masterRecordPerm.allowEditFiles;\n permissions.allowDelete = permissions.allowDelete && masterRecordPerm.allowDeleteFiles;\n if (!masterRecordPerm.modifyAllFiles && !isOwner) {\n permissions.allowEdit = false;\n permissions.allowDelete = false;\n }\n permissions.allowRead = permissions.allowRead && masterRecordPerm.allowReadFiles;\n if (!masterRecordPerm.viewAllFiles && !isOwner) {\n permissions.allowRead = false;\n }\n } else {\n if (Meteor.isClient) {\n user_company_ids = Steedos.getUserCompanyIds();\n } else {\n user_company_ids = Creator.getUserCompanyIds(userId, spaceId);\n }\n record_company_id = record != null ? record.company_id : void 0;\n if (record_company_id && _.isObject(record_company_id) && record_company_id._id) {\n record_company_id = record_company_id._id;\n }\n record_company_ids = record != null ? record.company_ids : void 0;\n if (record_company_ids && record_company_ids.length && _.isObject(record_company_ids[0])) {\n record_company_ids = record_company_ids.map(function(n) {\n return n._id;\n });\n }\n record_company_ids = _.union(record_company_ids, [record_company_id]);\n if (!permissions.modifyAllRecords && !isOwner && !permissions.modifyCompanyRecords) {\n permissions.allowEdit = false;\n permissions.allowDelete = false;\n } else if (!permissions.modifyAllRecords && permissions.modifyCompanyRecords) {\n if (record_company_ids && record_company_ids.length) {\n if (user_company_ids && user_company_ids.length) {\n if (!_.intersection(user_company_ids, record_company_ids).length) {\n permissions.allowEdit = false;\n permissions.allowDelete = false;\n }\n } else {\n permissions.allowEdit = false;\n permissions.allowDelete = false;\n }\n }\n }\n if (record.locked && !permissions.modifyAllRecords) {\n permissions.allowEdit = false;\n permissions.allowDelete = false;\n }\n if (!permissions.viewAllRecords && !isOwner && !permissions.viewCompanyRecords) {\n permissions.allowRead = false;\n } else if (!permissions.viewAllRecords && permissions.viewCompanyRecords) {\n if (record_company_ids && record_company_ids.length) {\n if (user_company_ids && user_company_ids.length) {\n if (!_.intersection(user_company_ids, record_company_ids).length) {\n permissions.allowRead = false;\n }\n } else {\n permissions.allowRead = false;\n }\n }\n }\n }\n }\n return permissions;\n};\n\nif (Meteor.isClient) {\n Creator.getRecordRelatedListPermissions = function(currentObjectName, relatedListItem, currentRecord, userId, spaceId) {\n var isRelateObjectUneditable, masterAllow, masterRecordPerm, relatedObjectPermissions, result, uneditable_related_list, write_requires_master_read;\n if (!currentObjectName && Meteor.isClient) {\n currentObjectName = Session.get(\"object_name\");\n }\n if (!relatedListItem) {\n console.error(\"relatedListItem must not be empty for the function Creator.getRecordRelatedListPermissions\");\n return {};\n }\n if (!currentRecord && Meteor.isClient) {\n currentRecord = Creator.getObjectRecord();\n }\n if (!userId && Meteor.isClient) {\n userId = Meteor.userId();\n }\n if (!spaceId && Meteor.isClient) {\n spaceId = Session.get(\"spaceId\");\n }\n masterRecordPerm = Creator.getRecordPermissions(currentObjectName, currentRecord, userId, spaceId);\n relatedObjectPermissions = Creator.getPermissions(relatedListItem.object_name);\n result = _.clone(relatedObjectPermissions);\n if (relatedListItem.is_file) {\n result.allowCreate = relatedObjectPermissions.allowCreate && masterRecordPerm.allowCreateFiles;\n result.allowEdit = relatedObjectPermissions.allowEdit && masterRecordPerm.allowEditFiles;\n } else {\n write_requires_master_read = relatedListItem.write_requires_master_read || false;\n masterAllow = false;\n if (write_requires_master_read === true) {\n masterAllow = masterRecordPerm.allowRead;\n } else if (write_requires_master_read === false) {\n masterAllow = masterRecordPerm.allowEdit;\n }\n uneditable_related_list = Creator.getRecordSafeRelatedList(currentRecord, currentObjectName);\n isRelateObjectUneditable = uneditable_related_list.indexOf(relatedListItem.object_name) > -1;\n result.allowCreate = masterAllow && relatedObjectPermissions.allowCreate && !isRelateObjectUneditable;\n result.allowEdit = masterAllow && relatedObjectPermissions.allowEdit && !isRelateObjectUneditable;\n }\n return result;\n };\n}\n\nif (Meteor.isServer) {\n Creator.getAllPermissions = function(spaceId, userId) {\n var _i, isSpaceAdmin, permissions, psets, psetsAdmin, psetsAdmin_pos, psetsCurrent, psetsCurrentNames, psetsCurrent_pos, psetsCustomer, psetsCustomer_pos, psetsGuest, psetsGuest_pos, psetsMember, psetsMember_pos, psetsSupplier, psetsSupplier_pos, psetsUser, psetsUser_pos, set_ids, spaceUser;\n permissions = {\n objects: {},\n assigned_apps: []\n };\n\n /*\n \t\t权限集说明:\n \t\t内置权限集-admin,user,member,guest,workflow_admin,organization_admin\n \t\t自定义权限集-数据库中新建的除内置权限集以外的其他权限集\n \t\t特定用户集合权限集(即users属性不可配置)-admin,user,member,guest\n \t\t可配置用户集合权限集(即users属性可配置)-workflow_admin,organization_admin以及自定义权限集\n */\n isSpaceAdmin = false;\n spaceUser = null;\n if (userId) {\n isSpaceAdmin = Creator.isSpaceAdmin(spaceId, userId);\n spaceUser = Creator.getCollection(\"space_users\").findOne({\n space: spaceId,\n user: userId\n }, {\n fields: {\n profile: 1\n }\n });\n }\n psetsAdmin = Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'admin'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n }) || null;\n psetsUser = Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'user'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n }) || null;\n psetsMember = Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'member'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n }) || null;\n psetsGuest = Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'guest'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n }) || null;\n psetsSupplier = Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'supplier'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n }) || null;\n psetsCustomer = Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'customer'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n }) || null;\n if (spaceUser && spaceUser.profile) {\n psetsCurrent = Creator.getCollection(\"permission_set\").find({\n space: spaceId,\n $or: [\n {\n users: userId\n }, {\n name: spaceUser.profile\n }\n ]\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1,\n name: 1\n }\n }).fetch();\n } else {\n psetsCurrent = Creator.getCollection(\"permission_set\").find({\n users: userId,\n space: spaceId\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1,\n name: 1\n }\n }).fetch();\n }\n psetsAdmin_pos = null;\n psetsUser_pos = null;\n psetsMember_pos = null;\n psetsGuest_pos = null;\n psetsCurrent_pos = null;\n psetsSupplier_pos = null;\n psetsCustomer_pos = null;\n if (psetsAdmin != null ? psetsAdmin._id : void 0) {\n psetsAdmin_pos = Creator.getCollection(\"permission_objects\").find({\n permission_set_id: psetsAdmin._id\n }, {\n fields: {\n created: 0,\n modified: 0,\n created_by: 0,\n modified_by: 0\n }\n }).fetch();\n }\n if (psetsUser != null ? psetsUser._id : void 0) {\n psetsUser_pos = Creator.getCollection(\"permission_objects\").find({\n permission_set_id: psetsUser._id\n }, {\n fields: {\n created: 0,\n modified: 0,\n created_by: 0,\n modified_by: 0\n }\n }).fetch();\n }\n if (psetsMember != null ? psetsMember._id : void 0) {\n psetsMember_pos = Creator.getCollection(\"permission_objects\").find({\n permission_set_id: psetsMember._id\n }, {\n fields: {\n created: 0,\n modified: 0,\n created_by: 0,\n modified_by: 0\n }\n }).fetch();\n }\n if (psetsGuest != null ? psetsGuest._id : void 0) {\n psetsGuest_pos = Creator.getCollection(\"permission_objects\").find({\n permission_set_id: psetsGuest._id\n }, {\n fields: {\n created: 0,\n modified: 0,\n created_by: 0,\n modified_by: 0\n }\n }).fetch();\n }\n if (psetsSupplier != null ? psetsSupplier._id : void 0) {\n psetsSupplier_pos = Creator.getCollection(\"permission_objects\").find({\n permission_set_id: psetsSupplier._id\n }, {\n fields: {\n created: 0,\n modified: 0,\n created_by: 0,\n modified_by: 0\n }\n }).fetch();\n }\n if (psetsCustomer != null ? psetsCustomer._id : void 0) {\n psetsCustomer_pos = Creator.getCollection(\"permission_objects\").find({\n permission_set_id: psetsCustomer._id\n }, {\n fields: {\n created: 0,\n modified: 0,\n created_by: 0,\n modified_by: 0\n }\n }).fetch();\n }\n if (psetsCurrent.length > 0) {\n set_ids = _.pluck(psetsCurrent, \"_id\");\n psetsCurrent_pos = Creator.getCollection(\"permission_objects\").find({\n permission_set_id: {\n $in: set_ids\n }\n }).fetch();\n psetsCurrentNames = _.pluck(psetsCurrent, \"name\");\n }\n psets = {\n psetsAdmin: psetsAdmin,\n psetsUser: psetsUser,\n psetsCurrent: psetsCurrent,\n psetsMember: psetsMember,\n psetsGuest: psetsGuest,\n psetsSupplier: psetsSupplier,\n psetsCustomer: psetsCustomer,\n isSpaceAdmin: isSpaceAdmin,\n spaceUser: spaceUser,\n psetsAdmin_pos: psetsAdmin_pos,\n psetsUser_pos: psetsUser_pos,\n psetsMember_pos: psetsMember_pos,\n psetsGuest_pos: psetsGuest_pos,\n psetsSupplier_pos: psetsSupplier_pos,\n psetsCustomer_pos: psetsCustomer_pos,\n psetsCurrent_pos: psetsCurrent_pos\n };\n permissions.assigned_apps = Creator.getAssignedApps.bind(psets)(spaceId, userId);\n permissions.assigned_menus = Creator.getAssignedMenus.bind(psets)(spaceId, userId);\n permissions.user_permission_sets = psetsCurrentNames;\n _i = 0;\n _.each(Creator.objectsByName, function(object, object_name) {\n _i++;\n if (!_.has(object, 'space') || !object.space || object.space === spaceId) {\n if (!_.has(object, 'in_development') || object.in_development === '0' || (object.in_development !== '0' && isSpaceAdmin)) {\n permissions.objects[object_name] = Creator.convertObject(clone(Creator.Objects[object_name]), spaceId);\n return permissions.objects[object_name][\"permissions\"] = Creator.getObjectPermissions.bind(psets)(spaceId, userId, object_name);\n }\n }\n });\n return permissions;\n };\n unionPlus = function(array, other) {\n if (!array && !other) {\n return void 0;\n }\n if (!array) {\n array = [];\n }\n if (!other) {\n other = [];\n }\n return _.union(array, other);\n };\n intersectionPlus = function(array, other) {\n if (!array && !other) {\n return void 0;\n }\n if (!array) {\n array = [];\n }\n if (!other) {\n other = [];\n }\n return _.intersection(array, other);\n };\n extendPermissionProps = function(target, props) {\n var filesProNames, propNames;\n propNames = permissionPropNames;\n return filesProNames = props ? _.each(propNames, function(propName) {\n return target[propName] = props[propName];\n }) : void 0;\n };\n overlayBaseBooleanPermissionProps = function(target, props) {\n var propNames;\n propNames = baseBooleanPermissionPropNames;\n return _.each(propNames, function(propName) {\n if (props[propName]) {\n return target[propName] = true;\n }\n });\n };\n Creator.getAssignedApps = function(spaceId, userId) {\n var apps, isSpaceAdmin, psetBase, psets, psetsAdmin, psetsCustomer, psetsSupplier, psetsUser, ref, ref1, spaceUser, userProfile;\n psetsAdmin = this.psetsAdmin || Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'admin'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n });\n psetsUser = this.psetsUser || Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'user'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n });\n psetsSupplier = this.psetsMember || Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'supplier'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n });\n psetsCustomer = this.psetsGuest || Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'customer'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n });\n spaceUser = null;\n if (userId) {\n spaceUser = Creator.getCollection(\"space_users\").findOne({\n space: spaceId,\n user: userId\n }, {\n fields: {\n profile: 1\n }\n });\n }\n if (spaceUser && spaceUser.profile) {\n psets = Creator.getCollection(\"permission_set\").find({\n space: spaceId,\n $or: [\n {\n users: userId\n }, {\n name: spaceUser.profile\n }\n ]\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1,\n name: 1\n }\n }).fetch();\n } else {\n psets = Creator.getCollection(\"permission_set\").find({\n users: userId,\n space: spaceId\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1,\n name: 1\n }\n }).fetch();\n }\n isSpaceAdmin = _.isBoolean(this.isSpaceAdmin) ? this.isSpaceAdmin : Creator.isSpaceAdmin(spaceId, userId);\n apps = [];\n if (isSpaceAdmin) {\n return [];\n } else {\n userProfile = (ref = Creator.getCollection(\"space_users\").findOne({\n space: spaceId,\n user: userId\n }, {\n fields: {\n profile: 1\n }\n })) != null ? ref.profile : void 0;\n psetBase = psetsUser;\n if (userProfile) {\n if (userProfile === 'supplier') {\n psetBase = psetsSupplier;\n } else if (userProfile === 'customer') {\n psetBase = psetsCustomer;\n }\n }\n if (psetBase != null ? (ref1 = psetBase.assigned_apps) != null ? ref1.length : void 0 : void 0) {\n apps = _.union(apps, psetBase.assigned_apps);\n } else {\n return [];\n }\n _.each(psets, function(pset) {\n if (!pset.assigned_apps) {\n return;\n }\n if (pset.name === \"admin\" || pset.name === \"user\" || pset.name === 'supplier' || pset.name === 'customer') {\n return;\n }\n return apps = _.union(apps, pset.assigned_apps);\n });\n return _.without(_.uniq(apps), void 0, null);\n }\n };\n Creator.getAssignedMenus = function(spaceId, userId) {\n var aboutMenu, adminMenus, allMenus, currentPsetNames, isSpaceAdmin, menus, otherMenuApps, otherMenus, psets, ref, ref1, result, userProfile;\n psets = this.psetsCurrent || Creator.getCollection(\"permission_set\").find({\n users: userId,\n space: spaceId\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1,\n name: 1\n }\n }).fetch();\n isSpaceAdmin = _.isBoolean(this.isSpaceAdmin) ? this.isSpaceAdmin : Creator.isSpaceAdmin(spaceId, userId);\n adminMenus = (ref = Creator.Apps.admin) != null ? ref.admin_menus : void 0;\n if (!adminMenus) {\n return [];\n }\n aboutMenu = adminMenus.find(function(n) {\n return n._id === 'about';\n });\n adminMenus = adminMenus.filter(function(n) {\n return n._id !== 'about';\n });\n otherMenuApps = _.sortBy(_.filter(_.values(Creator.Apps), function(n) {\n return n.admin_menus && n._id !== 'admin';\n }), 'sort');\n otherMenus = _.flatten(_.pluck(otherMenuApps, \"admin_menus\"));\n allMenus = _.union(adminMenus, otherMenus, [aboutMenu]);\n if (isSpaceAdmin) {\n result = allMenus;\n } else {\n userProfile = ((ref1 = Creator.getCollection(\"space_users\").findOne({\n space: spaceId,\n user: userId\n }, {\n fields: {\n profile: 1\n }\n })) != null ? ref1.profile : void 0) || 'user';\n currentPsetNames = psets.map(function(n) {\n return n.name;\n });\n menus = allMenus.filter(function(menu) {\n var psetsMenu;\n psetsMenu = menu.permission_sets;\n if (psetsMenu && psetsMenu.indexOf(userProfile) > -1) {\n return true;\n }\n return _.intersection(currentPsetNames, psetsMenu).length;\n });\n result = menus;\n }\n return _.sortBy(result, \"sort\");\n };\n findOne_permission_object = function(permission_objects, object_name, permission_set_id) {\n if (_.isNull(permission_objects)) {\n return null;\n }\n if (_.isArray(permission_objects)) {\n return _.find(permission_objects, function(po) {\n return po.object_name === object_name;\n });\n }\n return Creator.getCollection(\"permission_objects\").findOne({\n object_name: object_name,\n permission_set_id: permission_set_id\n });\n };\n find_permission_object = function(permission_objects, object_name, permission_set_ids) {\n if (_.isNull(permission_objects)) {\n return null;\n }\n if (_.isArray(permission_objects)) {\n return _.filter(permission_objects, function(po) {\n return po.object_name === object_name;\n });\n }\n return Creator.getCollection(\"permission_objects\").find({\n object_name: object_name,\n permission_set_id: {\n $in: permission_set_ids\n }\n }).fetch();\n };\n unionPermissionObjects = function(pos, object, psets) {\n var result;\n result = [];\n _.each(object.permission_set, function(ops, ops_key) {\n var currentPset, tempOps;\n if ([\"admin\", \"user\", \"member\", \"guest\"].indexOf(ops_key) < 0) {\n currentPset = psets.find(function(pset) {\n return pset.name === ops_key;\n });\n if (currentPset) {\n tempOps = _.clone(ops) || {};\n tempOps.permission_set_id = currentPset._id;\n tempOps.object_name = object.object_name;\n return result.push(tempOps);\n }\n }\n });\n if (result.length) {\n pos.forEach(function(po) {\n var repeatIndex, repeatPo;\n repeatIndex = 0;\n repeatPo = result.find(function(item, index) {\n repeatIndex = index;\n return item.permission_set_id === po.permission_set_id;\n });\n if (repeatPo) {\n return result[repeatIndex] = po;\n } else {\n return result.push(po);\n }\n });\n return result;\n } else {\n return pos;\n }\n };\n Creator.getObjectPermissions = function(spaceId, userId, object_name) {\n var isSpaceAdmin, object, opsetAdmin, opsetCustomer, opsetGuest, opsetMember, opsetSupplier, opsetUser, permissions, pos, posAdmin, posCustomer, posGuest, posMember, posSupplier, posUser, prof, psets, psetsAdmin, psetsAdmin_pos, psetsCurrent_pos, psetsCustomer, psetsCustomer_pos, psetsGuest, psetsGuest_pos, psetsMember, psetsMember_pos, psetsSupplier, psetsSupplier_pos, psetsUser, psetsUser_pos, set_ids, spaceUser;\n permissions = {};\n object = Creator.getObject(object_name, spaceId);\n if (spaceId === 'guest' || object_name === \"users\") {\n permissions = _.clone(object.permission_set.guest) || {};\n Creator.processPermissions(permissions);\n return permissions;\n }\n psetsAdmin = _.isNull(this.psetsAdmin) || this.psetsAdmin ? this.psetsAdmin : Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'admin'\n }, {\n fields: {\n _id: 1\n }\n });\n psetsUser = _.isNull(this.psetsUser) || this.psetsUser ? this.psetsUser : Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'user'\n }, {\n fields: {\n _id: 1\n }\n });\n psetsMember = _.isNull(this.psetsMember) || this.psetsMember ? this.psetsMember : Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'member'\n }, {\n fields: {\n _id: 1\n }\n });\n psetsGuest = _.isNull(this.psetsGuest) || this.psetsGuest ? this.psetsGuest : Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'guest'\n }, {\n fields: {\n _id: 1\n }\n });\n psetsSupplier = _.isNull(this.psetsSupplier) || this.psetsSupplier ? this.psetsSupplier : Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'supplier'\n }, {\n fields: {\n _id: 1\n }\n });\n psetsCustomer = _.isNull(this.psetsCustomer) || this.psetsCustomer ? this.psetsCustomer : Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'customer'\n }, {\n fields: {\n _id: 1\n }\n });\n psets = this.psetsCurrent;\n if (!psets) {\n spaceUser = null;\n if (userId) {\n spaceUser = Creator.getCollection(\"space_users\").findOne({\n space: spaceId,\n user: userId\n }, {\n fields: {\n profile: 1\n }\n });\n }\n if (spaceUser && spaceUser.profile) {\n psets = Creator.getCollection(\"permission_set\").find({\n space: spaceId,\n $or: [\n {\n users: userId\n }, {\n name: spaceUser.profile\n }\n ]\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1,\n name: 1\n }\n }).fetch();\n } else {\n psets = Creator.getCollection(\"permission_set\").find({\n users: userId,\n space: spaceId\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1,\n name: 1\n }\n }).fetch();\n }\n }\n isSpaceAdmin = _.isBoolean(this.isSpaceAdmin) ? this.isSpaceAdmin : Creator.isSpaceAdmin(spaceId, userId);\n psetsAdmin_pos = this.psetsAdmin_pos;\n psetsUser_pos = this.psetsUser_pos;\n psetsMember_pos = this.psetsMember_pos;\n psetsGuest_pos = this.psetsGuest_pos;\n psetsSupplier_pos = this.psetsSupplier_pos;\n psetsCustomer_pos = this.psetsCustomer_pos;\n psetsCurrent_pos = this.psetsCurrent_pos;\n opsetAdmin = _.clone(object.permission_set.admin) || {};\n opsetUser = _.clone(object.permission_set.user) || {};\n opsetMember = _.clone(object.permission_set.member) || {};\n opsetGuest = _.clone(object.permission_set.guest) || {};\n opsetSupplier = _.clone(object.permission_set.supplier) || {};\n opsetCustomer = _.clone(object.permission_set.customer) || {};\n if (psetsAdmin) {\n posAdmin = findOne_permission_object(psetsAdmin_pos, object_name, psetsAdmin._id);\n extendPermissionProps(opsetAdmin, posAdmin);\n }\n if (psetsUser) {\n posUser = findOne_permission_object(psetsUser_pos, object_name, psetsUser._id);\n extendPermissionProps(opsetUser, posUser);\n }\n if (psetsMember) {\n posMember = findOne_permission_object(psetsMember_pos, object_name, psetsMember._id);\n extendPermissionProps(opsetMember, posMember);\n }\n if (psetsGuest) {\n posGuest = findOne_permission_object(psetsGuest_pos, object_name, psetsGuest._id);\n extendPermissionProps(opsetGuest, posGuest);\n }\n if (psetsSupplier) {\n posSupplier = findOne_permission_object(psetsSupplier_pos, object_name, psetsSupplier._id);\n extendPermissionProps(opsetSupplier, posSupplier);\n }\n if (psetsCustomer) {\n posCustomer = findOne_permission_object(psetsCustomer_pos, object_name, psetsCustomer._id);\n extendPermissionProps(opsetCustomer, posCustomer);\n }\n if (!userId) {\n permissions = opsetAdmin;\n } else {\n if (isSpaceAdmin) {\n permissions = opsetAdmin;\n } else {\n if (spaceId === 'common') {\n permissions = opsetUser;\n } else {\n spaceUser = _.isNull(this.spaceUser) || this.spaceUser ? this.spaceUser : Creator.getCollection(\"space_users\").findOne({\n space: spaceId,\n user: userId\n }, {\n fields: {\n profile: 1\n }\n });\n if (spaceUser) {\n prof = spaceUser.profile;\n if (prof) {\n if (prof === 'user') {\n permissions = opsetUser;\n } else if (prof === 'member') {\n permissions = opsetMember;\n } else if (prof === 'guest') {\n permissions = opsetGuest;\n } else if (prof === 'supplier') {\n permissions = opsetSupplier;\n } else if (prof === 'customer') {\n permissions = opsetCustomer;\n }\n } else {\n permissions = opsetUser;\n }\n } else {\n permissions = opsetGuest;\n }\n }\n }\n }\n if (psets.length > 0) {\n set_ids = _.pluck(psets, \"_id\");\n pos = find_permission_object(psetsCurrent_pos, object_name, set_ids);\n pos = unionPermissionObjects(pos, object, psets);\n _.each(pos, function(po) {\n if (po.permission_set_id === (psetsAdmin != null ? psetsAdmin._id : void 0) || po.permission_set_id === (psetsUser != null ? psetsUser._id : void 0) || po.permission_set_id === (psetsMember != null ? psetsMember._id : void 0) || po.permission_set_id === (psetsGuest != null ? psetsGuest._id : void 0) || po.permission_set_id === (psetsSupplier != null ? psetsSupplier._id : void 0) || po.permission_set_id === (psetsCustomer != null ? psetsCustomer._id : void 0)) {\n return;\n }\n if (_.isEmpty(permissions)) {\n permissions = po;\n }\n overlayBaseBooleanPermissionProps(permissions, po);\n permissions.disabled_list_views = intersectionPlus(permissions.disabled_list_views, po.disabled_list_views);\n permissions.disabled_actions = intersectionPlus(permissions.disabled_actions, po.disabled_actions);\n permissions.unreadable_fields = intersectionPlus(permissions.unreadable_fields, po.unreadable_fields);\n permissions.uneditable_fields = intersectionPlus(permissions.uneditable_fields, po.uneditable_fields);\n permissions.unrelated_objects = intersectionPlus(permissions.unrelated_objects, po.unrelated_objects);\n return permissions.uneditable_related_list = intersectionPlus(permissions.uneditable_related_list, po.uneditable_related_list);\n });\n }\n if (object.is_view) {\n permissions.allowCreate = false;\n permissions.allowEdit = false;\n permissions.allowDelete = false;\n permissions.modifyAllRecords = false;\n permissions.modifyCompanyRecords = false;\n permissions.disabled_actions = [];\n }\n Creator.processPermissions(permissions);\n if (object.permission_set.owner) {\n permissions.owner = object.permission_set.owner;\n }\n return permissions;\n };\n Meteor.methods({\n \"creator.object_permissions\": function(spaceId) {\n return Creator.getAllPermissions(spaceId, this.userId);\n }\n });\n}\n","\nsteedosCore = require('@steedos/core')\n\nMeteor.startup ()->\n\tcreator_db_url = process.env.MONGO_URL_CREATOR\n\toplog_url = process.env.MONGO_OPLOG_URL_CREATOR\n\tif creator_db_url\n\t\tif !oplog_url\n\t\t\tthrow new Meteor.Error(500, \"Please configure environment variables: MONGO_OPLOG_URL_CREATOR\")\n\t\tCreator._CREATOR_DATASOURCE = {_driver: new MongoInternals.RemoteCollectionDriver(creator_db_url, {oplogUrl: oplog_url})}\n\nCreator.getCollectionName = (object)->\n#\tif object.table_name && object.table_name.endsWith(\"__c\")\n#\t\treturn object.table_name\n#\telse\n#\t\treturn object.name\n\treturn object.name\nCreator.createCollection = (object)->\n\tcollection_key = Creator.getCollectionName(object)\n\tif db[collection_key]\n\t\treturn db[collection_key]\n\telse if object.db\n\t\treturn object.db\n\n\tif Creator.Collections[collection_key]\n\t\treturn Creator.Collections[collection_key]\n\telse\n\t\tif object.custom\n\t\t\treturn steedosCore.newCollection(collection_key, Creator._CREATOR_DATASOURCE)\n\t\telse\n\t\t\tif collection_key == '_sms_queue' && SMSQueue?.collection\n\t\t\t\treturn SMSQueue.collection\n\t\t\treturn steedosCore.newCollection(collection_key)\n\n\n","var steedosCore;\n\nsteedosCore = require('@steedos/core');\n\nMeteor.startup(function() {\n var creator_db_url, oplog_url;\n creator_db_url = process.env.MONGO_URL_CREATOR;\n oplog_url = process.env.MONGO_OPLOG_URL_CREATOR;\n if (creator_db_url) {\n if (!oplog_url) {\n throw new Meteor.Error(500, \"Please configure environment variables: MONGO_OPLOG_URL_CREATOR\");\n }\n return Creator._CREATOR_DATASOURCE = {\n _driver: new MongoInternals.RemoteCollectionDriver(creator_db_url, {\n oplogUrl: oplog_url\n })\n };\n }\n});\n\nCreator.getCollectionName = function(object) {\n return object.name;\n};\n\nCreator.createCollection = function(object) {\n var collection_key;\n collection_key = Creator.getCollectionName(object);\n if (db[collection_key]) {\n return db[collection_key];\n } else if (object.db) {\n return object.db;\n }\n if (Creator.Collections[collection_key]) {\n return Creator.Collections[collection_key];\n } else {\n if (object.custom) {\n return steedosCore.newCollection(collection_key, Creator._CREATOR_DATASOURCE);\n } else {\n if (collection_key === '_sms_queue' && (typeof SMSQueue !== \"undefined\" && SMSQueue !== null ? SMSQueue.collection : void 0)) {\n return SMSQueue.collection;\n }\n return steedosCore.newCollection(collection_key);\n }\n }\n};\n","Creator.actionsByName = {}\n\nif Meteor.isClient\n\t# 定义全局 actions 函数\t\n\tCreator.actions = (actions)->\n\t\t_.each actions, (todo, action_name)->\n\t\t\tCreator.actionsByName[action_name] = todo \n\n\tCreator.executeAction = (object_name, action, record_id, item_element, list_view_id, record, callback)->\n\t\tif action && action.type == 'word-print'\n\t\t\tif record_id\n\t\t\t\tfilters = ['_id', '=', record_id]\n\t\t\telse\n\t\t\t\tfilters = ObjectGrid.getFilters(object_name, list_view_id, false, null, null)\n\t\t\turl = \"/api/v4/word_templates/\" + action.word_template + \"/print\" + \"?filters=\" + SteedosFilters.formatFiltersToODataQuery(filters);\n\t\t\turl = Steedos.absoluteUrl(url);\n\t\t\treturn window.open(url);\n\n\t\tobj = Creator.getObject(object_name)\n\t\tif action?.todo\n\t\t\tif typeof action.todo == \"string\"\n\t\t\t\ttodo = Creator.actionsByName[action.todo]\n\t\t\telse if typeof action.todo == \"function\"\n\t\t\t\ttodo = action.todo\t\n\t\t\tif !record && object_name && record_id\n\t\t\t\trecord = Creator.odata.get(object_name, record_id)\n\t\t\tif todo\n\t\t\t\t# item_element为空时应该设置默认值(对象的name字段),否则moreArgs拿到的后续参数位置就不对\n\t\t\t\titem_element = if item_element then item_element else \"\"\n\t\t\t\tmoreArgs = Array.prototype.slice.call(arguments, 3)\n\t\t\t\ttodoArgs = [object_name, record_id].concat(moreArgs)\n\t\t\t\ttodo.apply {\n\t\t\t\t\tobject_name: object_name\n\t\t\t\t\trecord_id: record_id\n\t\t\t\t\tobject: obj\n\t\t\t\t\taction: action\n\t\t\t\t\titem_element: item_element\n\t\t\t\t\trecord: record\n\t\t\t\t}, todoArgs\n\t\t\telse\n\t\t\t\ttoastr.warning(t(\"_object_actions_none_todo\"))\n\t\telse\n\t\t\ttoastr.warning(t(\"_object_actions_none_todo\"))\n\n\n\t_deleteRecord = (object_name, record_id, record_title, list_view_id, record, call_back, call_back_error)->\n\t\t# console.log(\"===_deleteRecord===\", object_name, record_id, record_title, list_view_id, record, call_back, call_back_error);\n\t\tobject = Creator.getObject(object_name)\n\t\tpreviousDoc = FormManager.getPreviousDoc(object_name, record_id, 'delete')\n\t\tCreator.odata.delete object_name, record_id, ()->\n\t\t\tif record_title\n\t\t\t\t# info = object.label + \"\\\"#{record_title}\\\"\" + \"已删除\"\n\t\t\t\tinfo =t \"creator_record_remove_swal_title_suc\", object.label + \"\\\"#{record_title}\\\"\"\n\t\t\telse\n\t\t\t\tinfo = t('creator_record_remove_swal_suc')\n\t\t\ttoastr.success info\n\t\t\tif call_back and typeof call_back == \"function\"\n\t\t\t\tcall_back()\n\n\t\t\tFormManager.runHook(object_name, 'delete', 'after', {_id: record_id, previousDoc: previousDoc})\n\t\t, (error)->\n\t\t\tif call_back_error and typeof call_back_error == \"function\"\n\t\t\t\tcall_back_error()\n\t\t\tFormManager.runHook(object_name, 'delete', 'error', {_id: record_id, error: error})\n\n\tCreator.relatedObjectStandardNew = (related_object_name)->\n\t\trelateObject = Creator.getObject(related_object_name)\n\t\tcollection_name = relateObject.label\n\t\tcollection = \"Creator.Collections.#{Creator.getObject(related_object_name)._collection_name}\"\n\t\tcurrent_object_name = Session.get(\"object_name\")\n\t\tcurrent_record_id = Session.get(\"record_id\")\n\t\tids = Creator.TabularSelectedIds[related_object_name]\n\t\tinitialValues = {};\n\t\tif ids?.length\n\t\t\t# 列表有选中项时,取第一个选中项,复制其内容到新建窗口中\n\t\t\t# 这的第一个指的是第一次勾选的选中项,而不是列表中已勾选的第一项\n\t\t\trecord_id = ids[0]\n\t\t\tdoc = Creator.odata.get(related_object_name, record_id)\n\t\t\tinitialValues = doc\n\t\t\t# “保存并新建”操作中自动打开的新窗口中需要再次复制最新的doc内容到新窗口中\n\t\t\tSession.set 'cmShowAgainDuplicated', true\n\t\telse\n\t\t\tdefaultDoc = FormManager.getRelatedInitialValues(current_object_name, current_record_id, related_object_name);\n\t\t\tif !_.isEmpty(defaultDoc)\n\t\t\t\tinitialValues = defaultDoc\n\t\tif relateObject?.version >= 2\n\t\t\treturn SteedosUI.showModal(stores.ComponentRegistry.components.ObjectForm, {\n\t\t\t\tname: \"#{related_object_name}_standard_new_form\",\n\t\t\t\tobjectApiName: related_object_name,\n\t\t\t\ttitle: '新建 ' + relateObject.label,\n\t\t\t\tinitialValues: initialValues,\n\t\t\t\tafterInsert: (result)->\n\t\t\t\t\tsetTimeout(()->\n\t\t\t\t\t\t# ObjectForm有缓存,新建子表记录可能会有汇总字段,需要刷新表单数据\n\t\t\t\t\t\tif Creator.getObject(current_object_name).version > 1\n\t\t\t\t\t\t\tSteedosUI.reloadRecord(current_object_name, current_record_id)\n\t\t\t\t\t\tFlowRouter.reload();\n\t\t\t\t\t, 1);\n\t\t\t\t\treturn true;\n\t\t\t}, null, {iconPath: '/assets/icons'})\n\n\n\t\tif ids?.length\n\t\t\t# 列表有选中项时,取第一个选中项,复制其内容到新建窗口中\n\t\t\t# 这的第一个指的是第一次勾选的选中项,而不是列表中已勾选的第一项\n\t\t\tSession.set 'cmDoc', initialValues\n\t\t\t# “保存并新建”操作中自动打开的新窗口中需要再次复制最新的doc内容到新窗口中\n\t\t\tSession.set 'cmShowAgainDuplicated', true\n\t\telse\n\t\t\tif !_.isEmpty(initialValues)\n\t\t\t\tSession.set 'cmDoc', initialValues\n\n\t\tSession.set(\"action_fields\", undefined)\n\t\tSession.set(\"action_collection\", collection)\n\t\tSession.set(\"action_collection_name\", collection_name)\n\t\tSession.set(\"action_save_and_insert\", false)\n\t\tMeteor.defer ()->\n\t\t\t$(\".creator-add-related\").click()\n\t\treturn\n\n\tCreator.actions \n\t\t# 在此定义全局 actions\n\t\t\"standard_query\": ()->\n\t\t\tModal.show(\"standard_query_modal\")\n\n\t\t\"standard_new\": (object_name, record_id, fields)->\n\t\t\t# current_record_id = Session.get(\"record_id\")\n\t\t\t# if current_record_id\n\t\t\t# \t# amis 相关子表右上角新建\n\t\t\t# \tCreator.relatedObjectStandardNew(object_name)\n\t\t\t# \treturn \n\t\t\tobject = Creator.getObject(object_name);\n\t\t\tgridName = this.action.gridName;\n\t\t\tisRelated = this.action.isRelated;\n\t\t\tif isRelated\n\t\t\t\trelatedFieldName = this.action.relatedFieldName;\n\t\t\t\tmasterRecordId = this.action.masterRecordId;\n\t\t\t\tinitialValues = this.action.initialValues\n\t\t\t\tif !initialValues\n\t\t\t\t\tinitialValues = {};\n\t\t\t\t\tinitialValues[relatedFieldName] = masterRecordId\n\t\t\telse\n\t\t\t\tinitialValues={}\n\t\t\t\tif(gridName)\n\t\t\t\t\tselectedRows = window.gridRefs?[gridName].current?.api?.getSelectedRows()\n\t\t\t\telse\n\t\t\t\t\tselectedRows = window.gridRef?.current?.api?.getSelectedRows()\t\n\t\t\t\t\n\t\t\t\tif selectedRows?.length\n\t\t\t\t\trecord_id = selectedRows[0]._id;\n\t\t\t\t\tif record_id\n\t\t\t\t\t\tinitialValues = Creator.odata.get(object_name, record_id)\n\n\t\t\t\telse\n\t\t\t\t\tinitialValues = FormManager.getInitialValues(object_name)\n\n\t\t\tif object?.version >= 2\n\t\t\t\treturn Steedos.Page.Form.StandardNew.render(Session.get(\"app_id\"), object_name, t('New') + ' ' + object.label, initialValues , {gridName: gridName});\n\t\t\tSession.set 'action_object_name', object_name\n\t\t\tif selectedRows?.length\n\t\t\t\t# 列表有选中项时,取第一个选中项,复制其内容到新建窗口中\n\t\t\t\t# 这的第一个指的是第一次勾选的选中项,而不是列表中已勾选的第一项\n\t\t\t\tSession.set 'cmDoc', initialValues\n\t\t\t\t# “保存并新建”操作中自动打开的新窗口中需要再次复制最新的doc内容到新窗口中\n\t\t\t\tSession.set 'cmShowAgainDuplicated', true\n\t\t\telse\n\t\t\t\tSession.set 'cmDoc', initialValues\n\t\t\tMeteor.defer ()->\n\t\t\t\t$(\".creator-add\").click()\n\t\t\treturn \n\n\t\t\"standard_open_view\": (object_name, record_id, fields)->\n\t\t\thref = Creator.getObjectUrl(object_name, record_id)\n\t\t\tFlowRouter.redirect(href)\n\t\t\treturn false\n\n\t\t\"standard_edit\": (object_name, record_id, fields)->\n\t\t\tif record_id\n\t\t\t\tobject = Creator.getObject(object_name);\n\t\t\t\tif object?.version >= 2\n\t\t\t\t\treturn Steedos.Page.Form.StandardEdit.render(Session.get(\"app_id\"), object_name, t('Edit') + ' ' + object.label, record_id, {\n\t\t\t\t\t\tgridName: this.action.gridName\n\t\t\t\t\t})\n\t\t\t\tif Steedos.isMobile() && false\n#\t\t\t\t\trecord = Creator.getObjectRecord(object_name, record_id)\n#\t\t\t\t\tSession.set 'cmDoc', record\n#\t\t\t\t\tSession.set 'reload_dxlist', false\n\t\t\t\t\tSession.set 'action_object_name', object_name\n\t\t\t\t\tSession.set 'action_record_id', record_id\n\t\t\t\t\tif this.record\n\t\t\t\t\t\tSession.set 'cmDoc', this.record\n\t\t\t\t\tMeteor.defer ()->\n\t\t\t\t\t\t$(\".btn-edit-record\").click()\n\t\t\t\telse\n\t\t\t\t\tSession.set 'action_object_name', object_name\n\t\t\t\t\tSession.set 'action_record_id', record_id\n\t\t\t\t\tif this.record\n\t\t\t\t\t\tSession.set 'cmDoc', this.record\n\t\t\t\t\t\tMeteor.defer ()->\n\t\t\t\t\t\t\t$(\".btn.creator-edit\").click()\n\n\t\t\"standard_delete\": (object_name, record_id, record_title, list_view_id, record, call_back)->\n\t\t\tgridName = this.action.gridName;\n\t\t\t# console.log(\"===standard_delete===\", object_name, record_id, record_title, list_view_id, record, call_back);\n\t\t\tif record_id\n\t\t\t\tbeforeHook = FormManager.runHook(object_name, 'delete', 'before', {_id: record_id})\n\t\t\t\tif !beforeHook\n\t\t\t\t\treturn false;\n\t\t\tobject = Creator.getObject(object_name)\n\t\t\tnameField = object.NAME_FIELD_KEY || \"name\"\n\n\t\t\tunless list_view_id\n\t\t\t\tlist_view_id = Session.get(\"list_view_id\")\n\t\t\tunless list_view_id\n\t\t\t\tlist_view_id = \"all\"\n\n\t\t\tif(!_.isString(record_title) && record_title)\n\t\t\t\trecord_title = record_title[nameField]\n\t\t\t\n\t\t\tif record && !record_title\n\t\t\t\trecord_title = record[nameField]\n\t\t\t\n\t\t\ti18nTitleKey = \"creator_record_remove_swal_title\"\n\t\t\ti18nTextKey = \"creator_record_remove_swal_text\"\n\n\t\t\tunless record_id\n\t\t\t\ti18nTitleKey = \"creator_record_remove_many_swal_title\"\n\t\t\t\ti18nTextKey = \"creator_record_remove_many_swal_text\"\n\n\t\t\t\t# 如果是批量删除,则传入的list_view_id为列表视图的name,用于获取列表选中项\n\t\t\t\t# 主列表规则是\"listview_#{object_name}_#{list_view_id}\",相关表规则是\"related_listview_#{object_name}_#{related_object_name}_#{related_field_name}\"\n\t\t\t\tselectedRecords = SteedosUI.getTableSelectedRows(gridName || list_view_id)\n\t\t\t\tif !selectedRecords || !selectedRecords.length\n\t\t\t\t\ttoastr.warning(t(\"creator_record_remove_many_no_selection\"))\n\t\t\t\t\treturn\n\n\t\t\tif record_title\n\t\t\t\ttext = t i18nTextKey, \"#{object.label} \\\"#{record_title}\\\"\"\n\t\t\telse\n\t\t\t\ttext = t i18nTextKey, \"#{object.label}\"\n\t\t\tswal\n\t\t\t\ttitle: t i18nTitleKey, \"#{object.label}\"\n\t\t\t\ttext: \"
#{text}
\"\n\t\t\t\thtml: true\n\t\t\t\tshowCancelButton:true\n\t\t\t\tconfirmButtonText: t('Delete')\n\t\t\t\tcancelButtonText: t('Cancel')\n\t\t\t\t(option) ->\n\t\t\t\t\tif option\n\t\t\t\t\t\tif record_id\n\t\t\t\t\t\t\t# 单条记录删除\n\t\t\t\t\t\t\t_deleteRecord object_name, record_id, record_title, list_view_id, record, ()->\n\t\t\t\t\t\t\t\t# 文件版本为\"cfs.files.filerecord\",需要替换为\"cfs-files-filerecord\"\n\t\t\t\t\t\t\t\tgridObjectNameClass = object_name.replace(/\\./g,\"-\")\n\t\t\t\t\t\t\t\tgridContainer = $(\".gridContainer.#{gridObjectNameClass}\")\n\t\t\t\t\t\t\t\tunless gridContainer?.length\n\t\t\t\t\t\t\t\t\tif window.opener\n\t\t\t\t\t\t\t\t\t\tisOpenerRemove = false\n\t\t\t\t\t\t\t\t\t\tgridContainer = window.opener.$(\".gridContainer.#{gridObjectNameClass}\")\n\t\t\t\t\t\t\t\ttry\n\t\t\t\t\t\t\t\t\t# ObjectForm有缓存,删除子表记录可能会有汇总字段,需要刷新表单数据\n\t\t\t\t\t\t\t\t\tcurrent_object_name = Session.get(\"object_name\")\n\t\t\t\t\t\t\t\t\tcurrent_record_id = Session.get(\"record_id\")\n\t\t\t\t\t\t\t\t\tif current_object_name && Creator.getObject(current_object_name)?.version > 1\n\t\t\t\t\t\t\t\t\t\tSteedosUI.reloadRecord(current_object_name, current_record_id)\n\t\t\t\t\t\t\t\t\tif FlowRouter.current().route.path.endsWith(\"/:record_id\")\n\t\t\t\t\t\t\t\t\t\tif object_name != Session.get(\"object_name\")\n\t\t\t\t\t\t\t\t\t\t\tFlowRouter.reload();\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\twindow.refreshGrid(gridName);\n\t\t\t\t\t\t\t\tcatch _e\n\t\t\t\t\t\t\t\t\tconsole.error(_e);\n\t\t\t\t\t\t\t\tif gridContainer?.length\n\t\t\t\t\t\t\t\t\tif object.enable_tree\n\t\t\t\t\t\t\t\t\t\tdxDataGridInstance = gridContainer.dxTreeList().dxTreeList('instance')\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tdxDataGridInstance = gridContainer.dxDataGrid().dxDataGrid('instance')\n\t\t\t\t\t\t\t\tif dxDataGridInstance\n\t\t\t\t\t\t\t\t\tif object.enable_tree\n\t\t\t\t\t\t\t\t\t\tdxDataGridInstance.refresh()\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tif object_name != Session.get(\"object_name\")\n\t\t\t\t\t\t\t\t\t\t\tFlowRouter.reload();\n\t\t\t\t\t\t\t\t\t\t# else\n\t\t\t\t\t\t\t\t\t\t# \tTemplate.creator_grid.refresh(dxDataGridInstance)\n\t\t\t\t\t\t\t\trecordUrl = Creator.getObjectUrl(object_name, record_id)\n\t\t\t\t\t\t\t\ttempNavRemoved = Creator.removeTempNavItem(object_name, recordUrl) #无论是在记录详细界面还是列表界面执行删除操作,都会把临时导航删除掉\n\t\t\t\t\t\t\t\tif isOpenerRemove or !dxDataGridInstance\n\t\t\t\t\t\t\t\t\tif isOpenerRemove\n\t\t\t\t\t\t\t\t\t\twindow.close()\n\t\t\t\t\t\t\t\t\telse if record_id == Session.get(\"record_id\") and list_view_id != 'calendar'\n\t\t\t\t\t\t\t\t\t\tappid = Session.get(\"app_id\")\n\t\t\t\t\t\t\t\t\t\tunless tempNavRemoved\n\t\t\t\t\t\t\t\t\t\t\t# 如果确实删除了临时导航,就可能已经重定向到上一个页面了,没必要再重定向一次\n\t\t\t\t\t\t\t\t\t\t\tFlowRouter.go \"/app/#{appid}/#{object_name}/grid/#{list_view_id}\"\n\t\t\t\t\t\t\t\tif call_back and typeof call_back == \"function\"\n\t\t\t\t\t\t\t\t\tcall_back()\t\t\t\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t# 批量删除\n\t\t\t\t\t\t\tif selectedRecords && selectedRecords.length\n\t\t\t\t\t\t\t\t$(\"body\").addClass(\"loading\")\n\t\t\t\t\t\t\t\tdeleteCounter = 0;\n\t\t\t\t\t\t\t\tafterBatchesDelete = ()->\n\t\t\t\t\t\t\t\t\tdeleteCounter++\n\t\t\t\t\t\t\t\t\tif deleteCounter >= selectedRecords.length\n\t\t\t\t\t\t\t\t\t\t# console.log(\"deleteCounter, selectedRecords.length===\", deleteCounter, selectedRecords.length);\n\t\t\t\t\t\t\t\t\t\t$(\"body\").removeClass(\"loading\")\n\t\t\t\t\t\t\t\t\t\twindow.refreshGrid(gridName);\n\t\t\t\t\t\t\t\tselectedRecords.forEach (record)->\n\t\t\t\t\t\t\t\t\trecord_id = record._id\n\t\t\t\t\t\t\t\t\tbeforeHook = FormManager.runHook(object_name, 'delete', 'before', {_id: record_id})\n\t\t\t\t\t\t\t\t\tif !beforeHook\n\t\t\t\t\t\t\t\t\t\tafterBatchesDelete()\n\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\trecordTitle = record[nameField] || record_id\n\t\t\t\t\t\t\t\t\t_deleteRecord object_name, record._id, recordTitle, list_view_id, record, (()->\n\t\t\t\t\t\t\t\t\t\trecordUrl = Creator.getObjectUrl(object_name, record_id)\n\t\t\t\t\t\t\t\t\t\tCreator.removeTempNavItem(object_name, recordUrl) #无论是在记录详细界面还是列表界面执行删除操作,都会把临时导航删除掉\n\t\t\t\t\t\t\t\t\t\tafterBatchesDelete()\n\t\t\t\t\t\t\t\t\t), ()->\n\t\t\t\t\t\t\t\t\t\tafterBatchesDelete()","var _deleteRecord;\n\nCreator.actionsByName = {};\n\nif (Meteor.isClient) {\n Creator.actions = function(actions) {\n return _.each(actions, function(todo, action_name) {\n return Creator.actionsByName[action_name] = todo;\n });\n };\n Creator.executeAction = function(object_name, action, record_id, item_element, list_view_id, record, callback) {\n var filters, moreArgs, obj, todo, todoArgs, url;\n if (action && action.type === 'word-print') {\n if (record_id) {\n filters = ['_id', '=', record_id];\n } else {\n filters = ObjectGrid.getFilters(object_name, list_view_id, false, null, null);\n }\n url = \"/api/v4/word_templates/\" + action.word_template + \"/print\" + \"?filters=\" + SteedosFilters.formatFiltersToODataQuery(filters);\n url = Steedos.absoluteUrl(url);\n return window.open(url);\n }\n obj = Creator.getObject(object_name);\n if (action != null ? action.todo : void 0) {\n if (typeof action.todo === \"string\") {\n todo = Creator.actionsByName[action.todo];\n } else if (typeof action.todo === \"function\") {\n todo = action.todo;\n }\n if (!record && object_name && record_id) {\n record = Creator.odata.get(object_name, record_id);\n }\n if (todo) {\n item_element = item_element ? item_element : \"\";\n moreArgs = Array.prototype.slice.call(arguments, 3);\n todoArgs = [object_name, record_id].concat(moreArgs);\n return todo.apply({\n object_name: object_name,\n record_id: record_id,\n object: obj,\n action: action,\n item_element: item_element,\n record: record\n }, todoArgs);\n } else {\n return toastr.warning(t(\"_object_actions_none_todo\"));\n }\n } else {\n return toastr.warning(t(\"_object_actions_none_todo\"));\n }\n };\n _deleteRecord = function(object_name, record_id, record_title, list_view_id, record, call_back, call_back_error) {\n var object, previousDoc;\n object = Creator.getObject(object_name);\n previousDoc = FormManager.getPreviousDoc(object_name, record_id, 'delete');\n return Creator.odata[\"delete\"](object_name, record_id, function() {\n var info;\n if (record_title) {\n info = t(\"creator_record_remove_swal_title_suc\", object.label + (\"\\\"\" + record_title + \"\\\"\"));\n } else {\n info = t('creator_record_remove_swal_suc');\n }\n toastr.success(info);\n if (call_back && typeof call_back === \"function\") {\n call_back();\n }\n return FormManager.runHook(object_name, 'delete', 'after', {\n _id: record_id,\n previousDoc: previousDoc\n });\n }, function(error) {\n if (call_back_error && typeof call_back_error === \"function\") {\n call_back_error();\n }\n return FormManager.runHook(object_name, 'delete', 'error', {\n _id: record_id,\n error: error\n });\n });\n };\n Creator.relatedObjectStandardNew = function(related_object_name) {\n var collection, collection_name, current_object_name, current_record_id, defaultDoc, doc, ids, initialValues, record_id, relateObject;\n relateObject = Creator.getObject(related_object_name);\n collection_name = relateObject.label;\n collection = \"Creator.Collections.\" + (Creator.getObject(related_object_name)._collection_name);\n current_object_name = Session.get(\"object_name\");\n current_record_id = Session.get(\"record_id\");\n ids = Creator.TabularSelectedIds[related_object_name];\n initialValues = {};\n if (ids != null ? ids.length : void 0) {\n record_id = ids[0];\n doc = Creator.odata.get(related_object_name, record_id);\n initialValues = doc;\n Session.set('cmShowAgainDuplicated', true);\n } else {\n defaultDoc = FormManager.getRelatedInitialValues(current_object_name, current_record_id, related_object_name);\n if (!_.isEmpty(defaultDoc)) {\n initialValues = defaultDoc;\n }\n }\n if ((relateObject != null ? relateObject.version : void 0) >= 2) {\n return SteedosUI.showModal(stores.ComponentRegistry.components.ObjectForm, {\n name: related_object_name + \"_standard_new_form\",\n objectApiName: related_object_name,\n title: '新建 ' + relateObject.label,\n initialValues: initialValues,\n afterInsert: function(result) {\n setTimeout(function() {\n if (Creator.getObject(current_object_name).version > 1) {\n SteedosUI.reloadRecord(current_object_name, current_record_id);\n }\n return FlowRouter.reload();\n }, 1);\n return true;\n }\n }, null, {\n iconPath: '/assets/icons'\n });\n }\n if (ids != null ? ids.length : void 0) {\n Session.set('cmDoc', initialValues);\n Session.set('cmShowAgainDuplicated', true);\n } else {\n if (!_.isEmpty(initialValues)) {\n Session.set('cmDoc', initialValues);\n }\n }\n Session.set(\"action_fields\", void 0);\n Session.set(\"action_collection\", collection);\n Session.set(\"action_collection_name\", collection_name);\n Session.set(\"action_save_and_insert\", false);\n Meteor.defer(function() {\n return $(\".creator-add-related\").click();\n });\n };\n Creator.actions({\n \"standard_query\": function() {\n return Modal.show(\"standard_query_modal\");\n },\n \"standard_new\": function(object_name, record_id, fields) {\n var gridName, initialValues, isRelated, masterRecordId, object, ref, ref1, ref2, ref3, ref4, ref5, relatedFieldName, selectedRows;\n object = Creator.getObject(object_name);\n gridName = this.action.gridName;\n isRelated = this.action.isRelated;\n if (isRelated) {\n relatedFieldName = this.action.relatedFieldName;\n masterRecordId = this.action.masterRecordId;\n initialValues = this.action.initialValues;\n if (!initialValues) {\n initialValues = {};\n initialValues[relatedFieldName] = masterRecordId;\n }\n } else {\n initialValues = {};\n if (gridName) {\n selectedRows = (ref = window.gridRefs) != null ? (ref1 = ref[gridName].current) != null ? (ref2 = ref1.api) != null ? ref2.getSelectedRows() : void 0 : void 0 : void 0;\n } else {\n selectedRows = (ref3 = window.gridRef) != null ? (ref4 = ref3.current) != null ? (ref5 = ref4.api) != null ? ref5.getSelectedRows() : void 0 : void 0 : void 0;\n }\n if (selectedRows != null ? selectedRows.length : void 0) {\n record_id = selectedRows[0]._id;\n if (record_id) {\n initialValues = Creator.odata.get(object_name, record_id);\n }\n } else {\n initialValues = FormManager.getInitialValues(object_name);\n }\n }\n if ((object != null ? object.version : void 0) >= 2) {\n return Steedos.Page.Form.StandardNew.render(Session.get(\"app_id\"), object_name, t('New') + ' ' + object.label, initialValues, {\n gridName: gridName\n });\n }\n Session.set('action_object_name', object_name);\n if (selectedRows != null ? selectedRows.length : void 0) {\n Session.set('cmDoc', initialValues);\n Session.set('cmShowAgainDuplicated', true);\n } else {\n Session.set('cmDoc', initialValues);\n }\n Meteor.defer(function() {\n return $(\".creator-add\").click();\n });\n },\n \"standard_open_view\": function(object_name, record_id, fields) {\n var href;\n href = Creator.getObjectUrl(object_name, record_id);\n FlowRouter.redirect(href);\n return false;\n },\n \"standard_edit\": function(object_name, record_id, fields) {\n var object;\n if (record_id) {\n object = Creator.getObject(object_name);\n if ((object != null ? object.version : void 0) >= 2) {\n return Steedos.Page.Form.StandardEdit.render(Session.get(\"app_id\"), object_name, t('Edit') + ' ' + object.label, record_id, {\n gridName: this.action.gridName\n });\n }\n if (Steedos.isMobile() && false) {\n Session.set('action_object_name', object_name);\n Session.set('action_record_id', record_id);\n if (this.record) {\n Session.set('cmDoc', this.record);\n }\n return Meteor.defer(function() {\n return $(\".btn-edit-record\").click();\n });\n } else {\n Session.set('action_object_name', object_name);\n Session.set('action_record_id', record_id);\n if (this.record) {\n Session.set('cmDoc', this.record);\n return Meteor.defer(function() {\n return $(\".btn.creator-edit\").click();\n });\n }\n }\n }\n },\n \"standard_delete\": function(object_name, record_id, record_title, list_view_id, record, call_back) {\n var beforeHook, gridName, i18nTextKey, i18nTitleKey, nameField, object, selectedRecords, text;\n gridName = this.action.gridName;\n if (record_id) {\n beforeHook = FormManager.runHook(object_name, 'delete', 'before', {\n _id: record_id\n });\n if (!beforeHook) {\n return false;\n }\n }\n object = Creator.getObject(object_name);\n nameField = object.NAME_FIELD_KEY || \"name\";\n if (!list_view_id) {\n list_view_id = Session.get(\"list_view_id\");\n }\n if (!list_view_id) {\n list_view_id = \"all\";\n }\n if (!_.isString(record_title) && record_title) {\n record_title = record_title[nameField];\n }\n if (record && !record_title) {\n record_title = record[nameField];\n }\n i18nTitleKey = \"creator_record_remove_swal_title\";\n i18nTextKey = \"creator_record_remove_swal_text\";\n if (!record_id) {\n i18nTitleKey = \"creator_record_remove_many_swal_title\";\n i18nTextKey = \"creator_record_remove_many_swal_text\";\n selectedRecords = SteedosUI.getTableSelectedRows(gridName || list_view_id);\n if (!selectedRecords || !selectedRecords.length) {\n toastr.warning(t(\"creator_record_remove_many_no_selection\"));\n return;\n }\n }\n if (record_title) {\n text = t(i18nTextKey, object.label + \" \\\"\" + record_title + \"\\\"\");\n } else {\n text = t(i18nTextKey, \"\" + object.label);\n }\n return swal({\n title: t(i18nTitleKey, \"\" + object.label),\n text: \"
\" + text + \"
\",\n html: true,\n showCancelButton: true,\n confirmButtonText: t('Delete'),\n cancelButtonText: t('Cancel')\n }, function(option) {\n var afterBatchesDelete, deleteCounter;\n if (option) {\n if (record_id) {\n return _deleteRecord(object_name, record_id, record_title, list_view_id, record, function() {\n var _e, appid, current_object_name, current_record_id, dxDataGridInstance, gridContainer, gridObjectNameClass, isOpenerRemove, recordUrl, ref, tempNavRemoved;\n gridObjectNameClass = object_name.replace(/\\./g, \"-\");\n gridContainer = $(\".gridContainer.\" + gridObjectNameClass);\n if (!(gridContainer != null ? gridContainer.length : void 0)) {\n if (window.opener) {\n isOpenerRemove = false;\n gridContainer = window.opener.$(\".gridContainer.\" + gridObjectNameClass);\n }\n }\n try {\n current_object_name = Session.get(\"object_name\");\n current_record_id = Session.get(\"record_id\");\n if (current_object_name && ((ref = Creator.getObject(current_object_name)) != null ? ref.version : void 0) > 1) {\n SteedosUI.reloadRecord(current_object_name, current_record_id);\n }\n if (FlowRouter.current().route.path.endsWith(\"/:record_id\")) {\n if (object_name !== Session.get(\"object_name\")) {\n FlowRouter.reload();\n }\n } else {\n window.refreshGrid(gridName);\n }\n } catch (error1) {\n _e = error1;\n console.error(_e);\n }\n if (gridContainer != null ? gridContainer.length : void 0) {\n if (object.enable_tree) {\n dxDataGridInstance = gridContainer.dxTreeList().dxTreeList('instance');\n } else {\n dxDataGridInstance = gridContainer.dxDataGrid().dxDataGrid('instance');\n }\n }\n if (dxDataGridInstance) {\n if (object.enable_tree) {\n dxDataGridInstance.refresh();\n } else {\n if (object_name !== Session.get(\"object_name\")) {\n FlowRouter.reload();\n }\n }\n }\n recordUrl = Creator.getObjectUrl(object_name, record_id);\n tempNavRemoved = Creator.removeTempNavItem(object_name, recordUrl);\n if (isOpenerRemove || !dxDataGridInstance) {\n if (isOpenerRemove) {\n window.close();\n } else if (record_id === Session.get(\"record_id\") && list_view_id !== 'calendar') {\n appid = Session.get(\"app_id\");\n if (!tempNavRemoved) {\n FlowRouter.go(\"/app/\" + appid + \"/\" + object_name + \"/grid/\" + list_view_id);\n }\n }\n }\n if (call_back && typeof call_back === \"function\") {\n return call_back();\n }\n });\n } else {\n if (selectedRecords && selectedRecords.length) {\n $(\"body\").addClass(\"loading\");\n deleteCounter = 0;\n afterBatchesDelete = function() {\n deleteCounter++;\n if (deleteCounter >= selectedRecords.length) {\n $(\"body\").removeClass(\"loading\");\n return window.refreshGrid(gridName);\n }\n };\n return selectedRecords.forEach(function(record) {\n var recordTitle;\n record_id = record._id;\n beforeHook = FormManager.runHook(object_name, 'delete', 'before', {\n _id: record_id\n });\n if (!beforeHook) {\n afterBatchesDelete();\n return;\n }\n recordTitle = record[nameField] || record_id;\n return _deleteRecord(object_name, record._id, recordTitle, list_view_id, record, (function() {\n var recordUrl;\n recordUrl = Creator.getObjectUrl(object_name, record_id);\n Creator.removeTempNavItem(object_name, recordUrl);\n return afterBatchesDelete();\n }), function() {\n return afterBatchesDelete();\n });\n });\n }\n }\n }\n });\n }\n });\n}\n"]} \ No newline at end of file +{"version":3,"sources":["meteor://💻app/packages/steedos_objects/core.coffee","meteor://💻app/core.coffee","meteor://💻app/packages/steedos_objects/loadStandardObjects.coffee","meteor://💻app/loadStandardObjects.coffee","meteor://💻app/packages/steedos_objects/coreSupport.coffee","meteor://💻app/coreSupport.coffee","meteor://💻app/packages/steedos_objects/server/methods/object_options.coffee","meteor://💻app/server/methods/object_options.coffee","meteor://💻app/packages/steedos_objects/lib/listviews.coffee","meteor://💻app/lib/listviews.coffee","meteor://💻app/packages/steedos_objects/lib/add_simple_schema_validation_error.coffee","meteor://💻app/lib/add_simple_schema_validation_error.coffee","meteor://💻app/packages/steedos_objects/lib/field_simple_schema_validation_error.coffee","meteor://💻app/lib/field_simple_schema_validation_error.coffee","meteor://💻app/packages/steedos:objects/lib/eval.js","meteor://💻app/packages/steedos_objects/lib/convert.coffee","meteor://💻app/lib/convert.coffee","meteor://💻app/packages/steedos_objects/lib/formular.coffee","meteor://💻app/lib/formular.coffee","meteor://💻app/packages/steedos_objects/lib/object.coffee","meteor://💻app/lib/object.coffee","meteor://💻app/packages/steedos_objects/lib/fields.coffee","meteor://💻app/lib/fields.coffee","meteor://💻app/packages/steedos_objects/lib/triggers.coffee","meteor://💻app/lib/triggers.coffee","meteor://💻app/packages/steedos_objects/lib/permission_sets.coffee","meteor://💻app/lib/permission_sets.coffee","meteor://💻app/packages/steedos_objects/lib/collections.coffee","meteor://💻app/lib/collections.coffee","meteor://💻app/packages/steedos_objects/lib/actions.coffee","meteor://💻app/lib/actions.coffee"],"names":["db","Creator","Objects","Collections","Menus","Apps","Dashboards","Reports","subs","steedosSchema","APIService","MetadataService","config","e","moleculer","objectql","packageLoader","packageService","path","settings","steedosCore","process","env","CREATOR_NODE_ENV","require","getSteedosConfig","built_in_plugins","plugins","Meteor","startup","apiService","broker","ex","metadataService","objectqlService","pageService","projectService","standardObjectsDir","standardObjectsPackageLoaderService","steedosService","uiService","ServiceBroker","namespace","nodeID","metadata","transporter","TRANSPORTER","cacher","CACHER","logLevel","serializer","requestTimeout","maxCallLevel","heartbeatInterval","heartbeatTimeout","contextParamsCloning","tracking","enabled","shutdownTimeout","disableBalancer","registry","strategy","preferLocal","bulkhead","concurrency","maxQueueSize","validator","errorHandler","tracing","exporter","type","options","logger","colors","width","gaugeWidth","skipProcessEventRegistration","created","warn","clean","init","createService","name","mixins","port","started","setTimeout","emit","getSteedosSchema","StandardObjectsPath","packageInfo","wrapAsync","cb","start","then","connectHandlersExpress","express","_restartService","use","staticRouter","waitForServices","console","log","SteedosApi","WebApp","connectHandlers","resolve","reject","error","Fiber","deps","app","Tracker","Dependency","object","_TEMPLATE","SimpleSchema","extendOptions","filtersFunction","Match","Optional","OneOf","Function","String","optionsFunction","createFunction","isServer","fiberLoadObjects","obj","object_name","loadObjects","run","list_views","space","getCollectionName","_","clone","convertObject","Object","initTriggers","initListViews","getObjectName","getObject","space_id","ref","ref1","isArray","isClient","depend","Session","get","objectsByName","getObjectById","object_id","findWhere","_id","removeObject","getCollection","spaceId","_collection_name","removeCollection","isSpaceAdmin","userId","findOne","fields","admins","indexOf","evaluateFormula","formular","context","isString","Formular","checkFormula","evaluateFilters","filters","selector","each","filter","action","value","length","isCommonSpace","getOrderlySetByIds","docs","ids","id_key","hit_first","values","getProperty","sortBy","doc","_index","v","sortingMethod","value1","value2","isValue1Empty","isValue2Empty","locale","key","Date","getTime","Steedos","toString","localeCompare","getObjectRelateds","_object","permissions","relatedList","relatedListMap","related_objects","isEmpty","objName","isObject","objectName","related_object","related_object_name","related_field","related_field_name","reference_to","foreign_key","write_requires_master_read","enableObjName","getPermissions","enable_audit","modifyAllRecords","enable_files","push","sfsFilesObject","splice","enable_tasks","enable_notes","enable_events","enable_instances","enable_approvals","enable_process","getUserContext","isUnSafeMode","USER_CONTEXT","space_user_org","su","suFields","Error","mobile","position","email","company","organization","company_id","company_ids","user","fullname","getRelativeUrl","url","isFunction","isCordova","startsWith","test","__meteor_runtime_config__","ROOT_URL_PATH_PREFIX","getUserCompanyId","getUserCompanyIds","processPermissions","po","allowCreate","allowRead","allowEdit","allowDelete","viewAllRecords","viewCompanyRecords","modifyCompanyRecords","allowReadFiles","viewAllFiles","allowCreateFiles","allowEditFiles","allowDeleteFiles","modifyAllFiles","getTemplateSpaceId","templateSpaceId","getCloudAdminSpaceId","cloudAdminSpaceId","isTemplateSpace","isCloudAdminSpace","steedosStorageDir","STEEDOS_STORAGE_DIR","methods","collection","name_field_key","options_limit","query","query_options","records","results","searchTextQuery","selected","sort","params","NAME_FIELD_KEY","searchText","$regex","$or","$in","extend","$nin","filterQuery","limit","find","fetch","record","label","message","JSON","stringify","getInitWidthPercent","columns","_schema","column_num","init_width_percent","getSchema","field_name","field","is_wide","ref2","pick","autoform","getFieldIsWide","getTabularOrder","list_view_id","setting","record_id","map","column","hidden","compact","order","index","default_extra_columns","extra_columns","getObjectDefaultColumns","getObjectDefaultExtraColumns","union","getObjectDefaultSort","TabularSelectedIds","convertListView","default_view","list_view","list_view_name","default_columns","default_mobile_columns","oitem","mobile_columns","has","include","filter_scope","parse","forEach","_value","getRelatedList","layoutRelatedList","list","mapList","objectLayoutRelatedListObjects","relatedListNames","relatedListObjects","related_object_names","unrelated_objects","related_lists","item","reFieldName","reObjectName","related","related_field_fullname","split","field_names","is_file","customRelatedListObject","actions","buttons","visible_on","page_size","objOrName","getRelatedObjects","related_object_item","relatedObject","tabular_order","getObjectFirstListViewColumns","without","transformSortToTabular","replace","pluck","difference","isActive","allow_relatedList","getObjectFirstListView","first","getListViews","getListView","exac","listViews","getListViewIsRecent","listView","pickObjectMobileColumns","count","getField","isNameColumn","itemCount","maxCount","maxRows","nameColumn","nameKey","result","getObjectDefaultView","defaultView","use_mobile_columns","isAllView","isRecentView","tabularColumns","tabular_sort","column_index","transformSortToDX","dx_sort","RegEx","code","RegExp","_regExMessages","_globalMessages","regEx","exp","msg","messages","evalInContext","js","eval","call","convertField","getOption","option","foo","color","allOptions","picklist","picklistOptions","getPicklist","getPickListOptions","reverse","enable","defaultValue","triggers","trigger","_todo","_todo_from_code","_todo_from_db","on","todo","systemBaseFields","omit","required","readonly","getSystemBaseFields","_visible","error1","actionsByName","trim","isExpression","visible","record_permissions","globalData","assign","now","parseSingleExpression","_options","_type","beforeOpenFunction","is_company_limited","max","min","_option","k","_regEx","_min","_max","Number","Boolean","_optionsFunction","_reference_to","_createFunction","_beforeOpenFunction","_filtersFunction","_defaultValue","_is_company_limited","_filters","isDate","pop","_is_date","form","val","relatedObjInfo","PREFIX","_prependPrefixForFormula","prefix","fieldVariable","reg","rev","m","$1","formula_str","_CONTEXT","_VALUES","data","isBoolean","toastr","formatObjectName","_baseObject","_db","defaultListViewId","disabled_list_views","ref3","schema","self","baseObject","permission_set","icon","description","is_view","hasImportTemplates","version","is_enable","allow_customActions","exclude_actions","enable_search","paging","enable_api","custom","enable_share","enable_tree","sidebar","open_window","filter_company","calendar","enable_chatter","enable_trash","enable_space_global","enable_follow","enable_workflow","enable_inline_edit","details","masters","lookup_details","in_development","idFieldName","database_name","is_name","primary","filterable","item_name","copyItem","admin","all","list_view_item","ReactiveVar","createCollection","_name","getObjectSchema","contains","attachSchema","_simpleSchema","getObjectODataRouterPrefix","bootstrapLoaded","getSelectOptions","fieldSchema","data_type","optionItem","fieldsArr","_ref_obj","autoform_type","collectionName","fs","fsType","isUnLimited","multiple","rows","language","isMobile","isPad","isiOS","afFieldInput","timezoneId","dxDateBoxOptions","displayFormat","pickerType","dateMobileOptions","outFormat","showIcon","dependOn","depend_on","create","lookup_field","Modal","show","formId","operation","onSuccess","addItems","reference_sort","optionsSort","reference_limit","optionsLimit","reference_to_field","referenceToField","blackbox","objectSwitche","optionsMethod","optionsMethodParams","references","_reference","link","defaultIcon","firstOption","decimal","precision","scale","disabled","Array","editable","accept","system","Email","isNumber","optional","unique","group","searchable","inlineHelpText","isProduction","sortable","getFieldDisplayValue","field_value","html","moment","format","checkFieldTypeSupportBetweenQuery","field_type","includes","pushBetweenBuiltinOptionals","operations","builtinValues","getBetweenBuiltinValues","builtinItem","is_check_only","getBetweenTimeBuiltinValues","getBetweenBuiltinValueItem","getBetweenTimeBuiltinValueItem","getBetweenBuiltinOperation","betweenBuiltinValues","getQuarterStartMonth","month","getMonth","getLastQuarterFirstDay","year","getFullYear","getNextQuarterFirstDay","getMonthDays","days","endDate","millisecond","startDate","getLastMonthFirstDay","currentMonth","currentYear","endValue","firstDay","lastDay","lastMonday","lastMonthFinalDay","lastMonthFirstDay","lastQuarterEndDay","lastQuarterStartDay","lastSunday","last_120_days","last_30_days","last_60_days","last_7_days","last_90_days","minusDay","monday","nextMonday","nextMonthFinalDay","nextMonthFirstDay","nextQuarterEndDay","nextQuarterStartDay","nextSunday","nextYear","next_120_days","next_30_days","next_60_days","next_7_days","next_90_days","previousYear","startValue","strEndDay","strFirstDay","strLastDay","strMonday","strStartDay","strSunday","strToday","strTomorrow","strYestday","sunday","thisQuarterEndDay","thisQuarterStartDay","tomorrow","week","yestday","getDay","t","fv","setHours","getHours","getTimezoneOffset","getFieldDefaultOperation","getFieldOperation","optionals","equal","unequal","less_than","greater_than","less_or_equal","greater_or_equal","not_contain","starts_with","between","getObjectFieldsName","fieldsName","sort_no","cleanTrigger","initTrigger","_trigger_hooks","ref4","ref5","todoWrapper","apply","arguments","when","before","insert","update","remove","after","_hook","trigger_name","_trigger_hook","baseBooleanPermissionPropNames","extendPermissionProps","findOne_permission_object","find_permission_object","intersectionPlus","otherPermissionPropNames","overlayBaseBooleanPermissionProps","permissionPropNames","unionPermissionObjects","unionPlus","getObjectPermissions","getRecordPermissions","isOwner","masterObjectName","masterRecordPerm","record_company_id","record_company_ids","user_company_ids","owner","parent","n","intersection","locked","getRecordRelatedListPermissions","currentObjectName","relatedListItem","currentRecord","isRelateObjectUneditable","masterAllow","relatedObjectPermissions","uneditable_related_list","getObjectRecord","getRecordSafeRelatedList","getAllPermissions","_i","psets","psetsAdmin","psetsAdmin_pos","psetsCurrent","psetsCurrentNames","psetsCurrent_pos","psetsCustomer","psetsCustomer_pos","psetsGuest","psetsGuest_pos","psetsMember","psetsMember_pos","psetsSupplier","psetsSupplier_pos","psetsUser","psetsUser_pos","set_ids","spaceUser","objects","assigned_apps","profile","users","permission_set_id","modified","created_by","modified_by","getAssignedApps","bind","assigned_menus","getAssignedMenus","user_permission_sets","array","other","target","props","filesProNames","propNames","propName","apps","psetBase","userProfile","pset","uniq","aboutMenu","adminMenus","allMenus","currentPsetNames","menus","otherMenuApps","otherMenus","admin_menus","flatten","menu","psetsMenu","permission_sets","permission_objects","isNull","permission_set_ids","pos","ops","ops_key","currentPset","tempOps","repeatIndex","repeatPo","opsetAdmin","opsetCustomer","opsetGuest","opsetMember","opsetSupplier","opsetUser","posAdmin","posCustomer","posGuest","posMember","posSupplier","posUser","prof","guest","member","supplier","customer","disabled_actions","unreadable_fields","uneditable_fields","creator_db_url","oplog_url","MONGO_URL_CREATOR","MONGO_OPLOG_URL_CREATOR","_CREATOR_DATASOURCE","_driver","MongoInternals","RemoteCollectionDriver","oplogUrl","collection_key","newCollection","SMSQueue","_deleteRecord","action_name","executeAction","item_element","callback","moreArgs","todoArgs","ObjectGrid","getFilters","word_template","SteedosFilters","formatFiltersToODataQuery","absoluteUrl","window","open","odata","prototype","slice","concat","warning","record_title","call_back","call_back_error","previousDoc","FormManager","getPreviousDoc","info","success","runHook","relatedObjectStandardNew","collection_name","current_object_name","current_record_id","defaultDoc","initialValues","relateObject","set","getRelatedInitialValues","SteedosUI","showModal","stores","ComponentRegistry","components","ObjectForm","objectApiName","title","afterInsert","reloadRecord","FlowRouter","reload","iconPath","defer","$","click","gridName","isRelated","masterRecordId","relatedFieldName","selectedRows","gridRefs","current","api","getSelectedRows","gridRef","getInitialValues","Page","Form","StandardNew","render","href","getObjectUrl","redirect","StandardEdit","beforeHook","i18nTextKey","i18nTitleKey","nameField","selectedRecords","text","getTableSelectedRows","swal","showCancelButton","confirmButtonText","cancelButtonText","afterBatchesDelete","deleteCounter","_e","appid","dxDataGridInstance","gridContainer","gridObjectNameClass","isOpenerRemove","recordUrl","tempNavRemoved","opener","route","endsWith","refreshGrid","dxTreeList","dxDataGrid","refresh","removeTempNavItem","close","go","addClass","removeClass","recordTitle"],"mappings":"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","file":"/packages/steedos_objects.js","sourcesContent":["@db = {}\nif !Creator?\n\t@Creator = {}\nCreator.Objects = {}\nCreator.Collections = {}\nCreator.Menus = []\nCreator.Apps = {}\nCreator.Dashboards = {}\nCreator.Reports = {}\nCreator.subs = {}\nCreator.steedosSchema = {}","this.db = {};\n\nif (typeof Creator === \"undefined\" || Creator === null) {\n this.Creator = {};\n}\n\nCreator.Objects = {};\n\nCreator.Collections = {};\n\nCreator.Menus = [];\n\nCreator.Apps = {};\n\nCreator.Dashboards = {};\n\nCreator.Reports = {};\n\nCreator.subs = {};\n\nCreator.steedosSchema = {};\n","try\n\tif process.env.CREATOR_NODE_ENV == 'development'\n\t\tsteedosCore = require('@steedos/core')\n\t\tobjectql = require('@steedos/objectql')\n\t\tmoleculer = require(\"moleculer\");\n\t\tpackageLoader = require('@steedos/service-meteor-package-loader');\n\t\tAPIService = require('@steedos/service-api');\n\t\tMetadataService = require('@steedos/service-metadata-server');\n\t\tpackageService = require(\"@steedos/service-package-registry\");\n\t\tpath = require('path')\n\n\t\tconfig = objectql.getSteedosConfig();\n\t\tsettings = {\n\t\t\tbuilt_in_plugins: [\n\t\t\t\t\"@steedos/standard-space\",\n\t\t\t\t\"@steedos/standard-object-database\",\n\t\t\t\t\"@steedos/standard-process-approval\",\n\t\t\t\t\"@steedos/standard-collaboration\",\n\t\t\t\t\"@steedos/standard-ui\",\n\t\t\t\t\"@steedos/standard-permission\",\n\t\t\t\t\"@steedos/webapp-public\",\n\t\t\t\t\"@steedos/service-cachers-manager\",\n\t\t\t\t\"@steedos/unpkg\",\n\t\t\t\t\"@steedos/workflow\",\n\t\t\t\t\"@steedos/accounts\",\n\t\t\t\t\"@steedos/plugin-company\",\n\t\t\t\t\"@steedos/metadata-api\",\n\t\t\t\t\"@steedos/data-import\",\n\t\t\t\t# \"@steedos/service-fields-indexs\",\n\t\t\t\t\"@steedos/service-accounts\",\n\t\t\t\t\"@steedos/service-charts\",\n\t\t\t\t# \"@steedos/service-pages\",\n\t\t\t\t\"@steedos/service-package-registry\",\n\t\t \t\t\"@steedos/service-package-tool\",\n\t\t\t\t# \"@steedos/standard-process\",\n\t\t\t\t\"@steedos/webapp-accounts\",\n\t\t\t\t\"@steedos/service-workflow\",\n\t\t\t\t\"@steedos/service-plugin-amis\",\n\t\t\t\t\"@steedos/service-files\",\n\t\t\t\t\"@steedos/service-sentry\",\n\t\t\t\t\"@steedos/service-identity-jwt\"\n\t\t\t],\n\t\t\tplugins: config.plugins\n\t\t}\n\t\tMeteor.startup ->\n\t\t\ttry\n\t\t\t\tbroker = new moleculer.ServiceBroker({\n\t\t\t\t\tnamespace: \"steedos\",\n\t\t\t\t\tnodeID: \"steedos-creator\",\n\t\t\t\t\tmetadata: {},\n\t\t\t\t\ttransporter: process.env.TRANSPORTER,\n\t\t\t\t\tcacher: process.env.CACHER,\n\t\t\t\t\tlogLevel: \"warn\",\n\t\t\t\t\tserializer: \"JSON\",\n\t\t\t\t\trequestTimeout: 60 * 1000,\n\t\t\t\t\tmaxCallLevel: 100,\n\n\t\t\t\t\theartbeatInterval: 10,\n\t\t\t\t\theartbeatTimeout: 30,\n\n\t\t\t\t\tcontextParamsCloning: false,\n\n\t\t\t\t\ttracking: {\n\t\t\t\t\t\tenabled: false,\n\t\t\t\t\t\tshutdownTimeout: 5000,\n\t\t\t\t\t},\n\n\t\t\t\t\tdisableBalancer: false,\n\n\t\t\t\t\tregistry: {\n\t\t\t\t\t\tstrategy: \"RoundRobin\",\n\t\t\t\t\t\tpreferLocal: true\n\t\t\t\t\t},\n\n\t\t\t\t\tbulkhead: {\n\t\t\t\t\t\tenabled: false,\n\t\t\t\t\t\tconcurrency: 10,\n\t\t\t\t\t\tmaxQueueSize: 100,\n\t\t\t\t\t},\n\t\t\t\t\tvalidator: true,\n\t\t\t\t\terrorHandler: null,\n\t\t\t\t\ttracing: {\n\t\t\t\t\t\tenabled: false,\n\t\t\t\t\t\texporter: {\n\t\t\t\t\t\t\ttype: \"Console\",\n\t\t\t\t\t\t\toptions: {\n\t\t\t\t\t\t\t\tlogger: null,\n\t\t\t\t\t\t\t\tcolors: true,\n\t\t\t\t\t\t\t\twidth: 100,\n\t\t\t\t\t\t\t\tgaugeWidth: 40\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t\tskipProcessEventRegistration: true,\n\n\t\t\t\t\tcreated: (broker)-> \n\t\t\t\t\t\t# Clear all cache entries\n\t\t\t\t\t\tbroker.logger.warn('Clear all cache entries on startup.')\n\t\t\t\t\t\tbroker.cacher.clean();\n\t\t\t\t});\n\n\t\t\t\tobjectql.broker.init(broker);\n\n\t\t\t\tobjectqlService = broker.createService(require(\"@steedos/service-objectql\"));\n\t\t\t\t\n\t\t\t\tprojectService = broker.createService({\n\t\t\t\t\tname: \"project-server\",\n\t\t\t\t\tnamespace: \"steedos\",\n\t\t\t\t\tmixins: [packageService],\n\t\t\t\t});\n\n\n\t\t\t\tmetadataService = broker.createService({\n\t\t\t\t\tname: 'metadata-server',\n\t\t\t\t\tmixins: [MetadataService],\n\t\t\t\t\tsettings: {\n\t\t\t\t\t} \n\t\t\t\t});\n\n\t\t\t\tuiService = broker.createService(require(\"@steedos/service-ui\"));\n\n\t\t\t\tapiService = broker.createService({\n\t\t\t\t\tname: \"api\",\n\t\t\t\t\tmixins: [APIService],\n\t\t\t\t\tsettings: {\n\t\t\t\t\t\tport: null\n\t\t\t\t\t} \n\t\t\t\t});\n\n\t\t\t\tpageService = broker.createService({\n\t\t\t\t\tname: \"@steedos/service-pages\",\n\t\t\t\t\tmixins: [require('@steedos/service-pages')],\n\t\t\t\t\tsettings: {\n\t\t\t\t\t\tport: null\n\t\t\t\t\t} \n\t\t\t\t});\n\n\t\t\t\tsteedosService = broker.createService({\n\t\t\t\t\tname: \"steedos-server\",\n\t\t\t\t\tmixins: [],\n\t\t\t\t\tsettings: {\n\t\t\t\t\t\tport: null\n\t\t\t\t\t},\n\t\t\t\t\tstarted: ()->\n\t\t\t\t\t\tsetTimeout ->\n\t\t\t\t\t\t\tbroker.emit 'steedos-server.started'\n\t\t\t\t\t\t\treturn\n\t\t\t\t\t\t, 1000\n\t\t\t\t});\n\n\t\t\t\tobjectql.getSteedosSchema(broker);\n\t\t\t\tstandardObjectsDir = objectql.StandardObjectsPath;\n\t\t\t\tstandardObjectsPackageLoaderService = broker.createService({\n\t\t\t\t\tname: 'standard-objects',\n\t\t\t\t\tmixins: [packageLoader],\n\t\t\t\t\tsettings: { packageInfo: {\n\t\t\t\t\t\tpath: standardObjectsDir,\n\t\t\t\t\t} }\n\t\t\t\t});\n\n\t\t\t\tMeteor.wrapAsync((cb)->\n\t\t\t\t\tbroker.start().then(()->\n\t\t\t\t\t\tif !broker.started \n\t\t\t\t\t\t\tbroker._restartService(objectqlService);\n\t\t\t\t\t\t\tbroker._restartService(standardObjectsPackageLoaderService);\n\t\t\t\t\t\t\tbroker._restartService(uiService);\n\n\t\t\t\t\t\texpress = require('express');\n\t\t\t\t\t\tconnectHandlersExpress = express();\n\t\t\t\t\t\tconnectHandlersExpress.use(require('@steedos/router').staticRouter());\n\t\t\t\t\t\tbroker.waitForServices('~packages-@steedos/service-ui').then ()->\n\t\t\t\t\t\t\tconsole.log('waitForServices ~packages-@steedos/service-ui')\n\t\t\t\t\t\t\tconnectHandlersExpress.use(SteedosApi.express())\n\t\t\t\t\t\t\tWebApp.connectHandlers.use(connectHandlersExpress)\n\t\t\t\t\t\t\n\t\t\t\t\t\t# steedosCore.init(settings).then ()->\n\t\t\t\t\t\t# \tcb();\n\n\t\t\t\t\t\tbroker.waitForServices(standardObjectsPackageLoaderService.name).then (resolve, reject) ->\n\t\t\t\t\t\t\tsteedosCore.init(settings).then ()->\n\t\t\t\t\t\t\t\tcb(reject, resolve)\n\t\t\t\t\t)\n\t\t\t\t)()\n\t\t\tcatch ex\n\t\t\t\tconsole.error(\"error:\",ex)\ncatch e\n\tconsole.error(\"error:\",e)","var APIService, MetadataService, config, e, moleculer, objectql, packageLoader, packageService, path, settings, steedosCore;\n\ntry {\n if (process.env.CREATOR_NODE_ENV === 'development') {\n steedosCore = require('@steedos/core');\n objectql = require('@steedos/objectql');\n moleculer = require(\"moleculer\");\n packageLoader = require('@steedos/service-meteor-package-loader');\n APIService = require('@steedos/service-api');\n MetadataService = require('@steedos/service-metadata-server');\n packageService = require(\"@steedos/service-package-registry\");\n path = require('path');\n config = objectql.getSteedosConfig();\n settings = {\n built_in_plugins: [\"@steedos/standard-space\", \"@steedos/standard-object-database\", \"@steedos/standard-process-approval\", \"@steedos/standard-collaboration\", \"@steedos/standard-ui\", \"@steedos/standard-permission\", \"@steedos/webapp-public\", \"@steedos/service-cachers-manager\", \"@steedos/unpkg\", \"@steedos/workflow\", \"@steedos/accounts\", \"@steedos/plugin-company\", \"@steedos/metadata-api\", \"@steedos/data-import\", \"@steedos/service-accounts\", \"@steedos/service-charts\", \"@steedos/service-package-registry\", \"@steedos/service-package-tool\", \"@steedos/webapp-accounts\", \"@steedos/service-workflow\", \"@steedos/service-plugin-amis\", \"@steedos/service-files\", \"@steedos/service-sentry\", \"@steedos/service-identity-jwt\"],\n plugins: config.plugins\n };\n Meteor.startup(function() {\n var apiService, broker, ex, metadataService, objectqlService, pageService, projectService, standardObjectsDir, standardObjectsPackageLoaderService, steedosService, uiService;\n try {\n broker = new moleculer.ServiceBroker({\n namespace: \"steedos\",\n nodeID: \"steedos-creator\",\n metadata: {},\n transporter: process.env.TRANSPORTER,\n cacher: process.env.CACHER,\n logLevel: \"warn\",\n serializer: \"JSON\",\n requestTimeout: 60 * 1000,\n maxCallLevel: 100,\n heartbeatInterval: 10,\n heartbeatTimeout: 30,\n contextParamsCloning: false,\n tracking: {\n enabled: false,\n shutdownTimeout: 5000\n },\n disableBalancer: false,\n registry: {\n strategy: \"RoundRobin\",\n preferLocal: true\n },\n bulkhead: {\n enabled: false,\n concurrency: 10,\n maxQueueSize: 100\n },\n validator: true,\n errorHandler: null,\n tracing: {\n enabled: false,\n exporter: {\n type: \"Console\",\n options: {\n logger: null,\n colors: true,\n width: 100,\n gaugeWidth: 40\n }\n }\n },\n skipProcessEventRegistration: true,\n created: function(broker) {\n broker.logger.warn('Clear all cache entries on startup.');\n return broker.cacher.clean();\n }\n });\n objectql.broker.init(broker);\n objectqlService = broker.createService(require(\"@steedos/service-objectql\"));\n projectService = broker.createService({\n name: \"project-server\",\n namespace: \"steedos\",\n mixins: [packageService]\n });\n metadataService = broker.createService({\n name: 'metadata-server',\n mixins: [MetadataService],\n settings: {}\n });\n uiService = broker.createService(require(\"@steedos/service-ui\"));\n apiService = broker.createService({\n name: \"api\",\n mixins: [APIService],\n settings: {\n port: null\n }\n });\n pageService = broker.createService({\n name: \"@steedos/service-pages\",\n mixins: [require('@steedos/service-pages')],\n settings: {\n port: null\n }\n });\n steedosService = broker.createService({\n name: \"steedos-server\",\n mixins: [],\n settings: {\n port: null\n },\n started: function() {\n return setTimeout(function() {\n broker.emit('steedos-server.started');\n }, 1000);\n }\n });\n objectql.getSteedosSchema(broker);\n standardObjectsDir = objectql.StandardObjectsPath;\n standardObjectsPackageLoaderService = broker.createService({\n name: 'standard-objects',\n mixins: [packageLoader],\n settings: {\n packageInfo: {\n path: standardObjectsDir\n }\n }\n });\n return Meteor.wrapAsync(function(cb) {\n return broker.start().then(function() {\n var connectHandlersExpress, express;\n if (!broker.started) {\n broker._restartService(objectqlService);\n broker._restartService(standardObjectsPackageLoaderService);\n broker._restartService(uiService);\n }\n express = require('express');\n connectHandlersExpress = express();\n connectHandlersExpress.use(require('@steedos/router').staticRouter());\n broker.waitForServices('~packages-@steedos/service-ui').then(function() {\n console.log('waitForServices ~packages-@steedos/service-ui');\n connectHandlersExpress.use(SteedosApi.express());\n return WebApp.connectHandlers.use(connectHandlersExpress);\n });\n return broker.waitForServices(standardObjectsPackageLoaderService.name).then(function(resolve, reject) {\n return steedosCore.init(settings).then(function() {\n return cb(reject, resolve);\n });\n });\n });\n })();\n } catch (error) {\n ex = error;\n return console.error(\"error:\", ex);\n }\n });\n }\n} catch (error) {\n e = error;\n console.error(\"error:\", e);\n}\n","Creator.deps = {\n\tapp: new Tracker.Dependency\n\tobject: new Tracker.Dependency\n};\n\nCreator._TEMPLATE = {\n\tApps: {},\n\tObjects: {}\n}\n\nMeteor.startup ->\n\tSimpleSchema.extendOptions({filtersFunction: Match.Optional(Match.OneOf(Function, String))})\n\tSimpleSchema.extendOptions({optionsFunction: Match.Optional(Match.OneOf(Function, String))})\n\tSimpleSchema.extendOptions({createFunction: Match.Optional(Match.OneOf(Function, String))})\n\n# Creator.fiberLoadObjects 供steedos-cli项目使用\nif Meteor.isServer\n\tFiber = require('fibers')\n\tCreator.fiberLoadObjects = (obj, object_name)->\n\t\tFiber(()->\n\t\t\tCreator.loadObjects(obj, object_name)\n\t\t).run()\n\nCreator.loadObjects = (obj, object_name)->\n\tif !object_name\n\t\tobject_name = obj.name\n\n\tif !obj.list_views\n\t\tobj.list_views = {}\n\n\tif obj.space\n\t\tobject_name = Creator.getCollectionName(obj)\n\tif object_name == 'cfs_files_filerecord'\n\t\tobject_name = 'cfs.files.filerecord'\n\t\tobj = _.clone(obj)\n\t\tobj.name = object_name\n\t\tCreator.Objects[object_name] = obj\n\n\tCreator.convertObject(obj)\n\tnew Creator.Object(obj);\n\n\tCreator.initTriggers(object_name)\n\tCreator.initListViews(object_name)\n\treturn obj\n\nCreator.getObjectName = (object) ->\n\tif object.space\n\t\treturn \"c_#{object.space}_#{object.name}\"\n\treturn object.name\n\nCreator.getObject = (object_name, space_id)->\n\tif _.isArray(object_name)\n\t\treturn ;\n\tif Meteor.isClient\n\t\tCreator.deps?.object?.depend()\n\tif !object_name and Meteor.isClient\n\t\tobject_name = Session.get(\"object_name\")\n\n#\tif !space_id && object_name\n#\t\tif Meteor.isClient && !object_name.startsWith('c_')\n#\t\t\tspace_id = Session.get(\"spaceId\")\n\n\tif object_name\n#\t\tif space_id\n#\t\t\tobj = Creator.objectsByName[\"c_#{space_id}_#{object_name}\"]\n#\t\t\tif obj\n#\t\t\t\treturn obj\n#\n#\t\tobj = _.find Creator.objectsByName, (o)->\n#\t\t\t\treturn o._collection_name == object_name\n#\t\tif obj\n#\t\t\treturn obj\n\n\t\treturn Creator.objectsByName[object_name]\n\nCreator.getObjectById = (object_id)->\n\treturn _.findWhere(Creator.objectsByName, {_id: object_id})\n\nCreator.removeObject = (object_name)->\n\tconsole.log(\"removeObject\", object_name)\n\tdelete Creator.Objects[object_name]\n\tdelete Creator.objectsByName[object_name]\n\nCreator.getCollection = (object_name, spaceId)->\n\tif !object_name\n\t\tobject_name = Session.get(\"object_name\")\n\tif object_name\n\t\tif Meteor.isClient\n\t\t\treturn db[object_name]\n\t\telse\n\t\t\treturn Creator.Collections[Creator.getObject(object_name, spaceId)?._collection_name || object_name]\n\nCreator.removeCollection = (object_name)->\n\tdelete Creator.Collections[object_name]\n\nCreator.isSpaceAdmin = (spaceId, userId)->\n\tif Meteor.isClient\n\t\tif !spaceId\n\t\t\tspaceId = Session.get(\"spaceId\")\n\t\tif !userId\n\t\t\tuserId = Meteor.userId()\n\n\tspace = Creator.getObject(\"spaces\")?.db?.findOne(spaceId,{fields:{admins:1}})\n\tif space?.admins\n\t\treturn space.admins.indexOf(userId) >= 0\n\n\nCreator.evaluateFormula = (formular, context, options)->\n\n\tif !_.isString(formular)\n\t\treturn formular\n\n\tif Creator.Formular.checkFormula(formular)\n\t\treturn Creator.Formular.run(formular, context, options)\n\n\treturn formular\n\nCreator.evaluateFilters = (filters, context)->\n\tselector = {}\n\t_.each filters, (filter)->\n\t\tif filter?.length == 3\n\t\t\tname = filter[0]\n\t\t\taction = filter[1]\n\t\t\tvalue = Creator.evaluateFormula(filter[2], context)\n\t\t\tselector[name] = {}\n\t\t\tselector[name][action] = value\n\t# console.log(\"evaluateFilters-->selector\", selector)\n\treturn selector\n\nCreator.isCommonSpace = (spaceId) ->\n\treturn spaceId == 'common'\n\n###\n\tdocs:待排序的文档数组\n\tids:_id集合\n\tid_key: 默认为_id\n\treturn 按照ids的顺序返回新的文档集合\n###\nCreator.getOrderlySetByIds = (docs, ids, id_key, hit_first)->\n\n\tif !id_key\n\t\tid_key = \"_id\"\n\n\tif hit_first\n\n\t\t#由于不能使用_.findIndex函数,因此此处先将对象数组转为普通数组类型,在获取其index\n\t\tvalues = docs.getProperty(id_key)\n\n\t\treturn\t_.sortBy docs, (doc)->\n\t\t\t\t\t_index = ids.indexOf(doc[id_key])\n\t\t\t\t\tif _index > -1\n\t\t\t\t\t\treturn _index\n\t\t\t\t\telse\n\t\t\t\t\t\treturn ids.length + _.indexOf(values, doc[id_key])\n\telse\n\t\treturn\t_.sortBy docs, (doc)->\n\t\t\tv = ids.indexOf(doc[id_key]);\n\t\t\tif v < 0\n\t\t\t\treturn 99999\n\t\t\telse \n\t\t\t\treturn v\n\n###\n\t按用户所属本地化语言进行排序,支持中文、数值、日期等字段排序\n\t对于Object类型,如果提供作用域中key属性,则取值为value[key]进行排序比较,反之整个Object.toString()后排序比较\n###\nCreator.sortingMethod = (value1, value2) ->\n\tif this.key\n\t\tvalue1 = value1[this.key]\n\t\tvalue2 = value2[this.key]\n\tif value1 instanceof Date\n\t\tvalue1 = value1.getTime()\n\tif value2 instanceof Date\n\t\tvalue2 = value2.getTime()\n\tif typeof value1 is \"number\" and typeof value2 is \"number\"\n\t\treturn value1 - value2\n\t# Handling null values\n\tisValue1Empty = value1 == null or value1 == undefined\n\tisValue2Empty = value2 == null or value2 == undefined\n\tif isValue1Empty and !isValue2Empty\n\t\treturn -1\n\tif isValue1Empty and isValue2Empty\n\t\treturn 0\n\tif !isValue1Empty and isValue2Empty\n\t\treturn 1\n\tlocale = Steedos.locale()\n\treturn value1.toString().localeCompare value2.toString(), locale\n\n\n# 该函数只在初始化Object时,把相关对象的计算结果保存到Object的related_objects属性中,后续可以直接从related_objects属性中取得计算结果而不用再次调用该函数来计算\nCreator.getObjectRelateds = (object_name)->\n\tif Meteor.isClient\n\t\tif !object_name\n\t\t\tobject_name = Session.get(\"object_name\")\n\n\trelated_objects = []\n\t# _object = Creator.getObject(object_name)\n\t# 因Creator.getObject函数内部要调用该函数,所以这里不可以调用Creator.getObject取对象,只能调用Creator.Objects来取对象\n\t_object = Creator.Objects[object_name]\n\tif !_object\n\t\treturn related_objects\n\t\n\trelatedList = _object.relatedList\n\tif Meteor.isClient && !_.isEmpty relatedList\n\t\trelatedListMap = {}\n\t\t_.each relatedList, (objName)->\n\t\t\tif _.isObject objName\n\t\t\t\trelatedListMap[objName.objectName] = {}\n\t\t\telse\n\t\t\t\trelatedListMap[objName] = {}\n\t\t_.each Creator.Objects, (related_object, related_object_name)->\n\t\t\t_.each related_object.fields, (related_field, related_field_name)->\n\t\t\t\tif (related_field.type == \"master_detail\" || related_field.type == \"lookup\") and related_field.reference_to and related_field.reference_to == object_name and relatedListMap[related_object_name]\n\t\t\t\t\t# 当related_object.fields中有两个或以上的字段指向object_name表示的对象时,优先取第一个作为外键关系字段,但是related_field为主子表时强行覆盖之前的relatedListMap[related_object_name]值\n\t\t\t\t\tif _.isEmpty relatedListMap[related_object_name] || related_field.type == \"master_detail\"\n\t\t\t\t\t\trelatedListMap[related_object_name] = { object_name: related_object_name, foreign_key: related_field_name, write_requires_master_read: related_field.write_requires_master_read }\n\t\tif relatedListMap['cms_files']\n\t\t\trelatedListMap['cms_files'] = { object_name: \"cms_files\", foreign_key: \"parent\" }\n\t\tif relatedListMap['instances']\n\t\t\trelatedListMap['instances'] = { object_name: \"instances\", foreign_key: \"record_ids\" }\n\t\t_.each ['tasks', 'notes', 'events', 'approvals'], (enableObjName)->\n\t\t\tif relatedListMap[enableObjName]\n\t\t\t\trelatedListMap[enableObjName] = { object_name: enableObjName, foreign_key: \"related_to\" }\n\t\tif relatedListMap['audit_records']\n\t\t\t#record 详细下的audit_records仅modifyAllRecords权限可见\n\t\t\tpermissions = Creator.getPermissions(object_name)\n\t\t\tif _object.enable_audit && permissions?.modifyAllRecords\n\t\t\t\trelatedListMap['audit_records'] = { object_name:\"audit_records\", foreign_key: \"related_to\" }\n\t\trelated_objects = _.values relatedListMap\n\t\treturn related_objects\n\n\tif _object.enable_files\n\t\trelated_objects.push {object_name:\"cms_files\", foreign_key: \"parent\"}\n\n\t_.each Creator.Objects, (related_object, related_object_name)->\n\t\tif related_object_name == \"cfs.files.filerecord\"\n\t\t\t# cfs.files.filerecord对象在第二次点击的时候related_object返回的是app-builder中的\"metadata.parent\"字段被删除了,记到metadata字段的sub_fields中了,所以要单独处理。\n\t\t\tsfsFilesObject = Creator.getObject(\"cfs.files.filerecord\")\n\t\t\tsfsFilesObject && related_object = sfsFilesObject\n\t\t_.each related_object.fields, (related_field, related_field_name)->\n\t\t\tif (related_field.type == \"master_detail\" || (related_field.type == \"lookup\" && related_field.relatedList)) and related_field.reference_to and related_field.reference_to == object_name\n\t\t\t\tif related_object_name == \"object_fields\"\n\t\t\t\t\t#TODO 待相关列表支持排序后,删除此判断\n\t\t\t\t\trelated_objects.splice(0, 0, {object_name:related_object_name, foreign_key: related_field_name})\n\t\t\t\telse\n\t\t\t\t\trelated_objects.push {object_name:related_object_name, foreign_key: related_field_name, write_requires_master_read: related_field.write_requires_master_read}\n\n\tif _object.enable_tasks\n\t\trelated_objects.push {object_name:\"tasks\", foreign_key: \"related_to\"}\n\tif _object.enable_notes\n\t\trelated_objects.push {object_name:\"notes\", foreign_key: \"related_to\"}\n\tif _object.enable_events\n\t\trelated_objects.push {object_name:\"events\", foreign_key: \"related_to\"}\n\tif _object.enable_instances\n\t\trelated_objects.push {object_name:\"instances\", foreign_key: \"record_ids\"}\n\tif _object.enable_approvals\n\t\trelated_objects.push {object_name:\"approvals\", foreign_key: \"related_to\"}\n\tif _object.enable_process\n\t\trelated_objects.push {object_name:\"process_instance_history\", foreign_key: \"target_object\"}\n\t#record 详细下的audit_records仅modifyAllRecords权限可见\n\tif Meteor.isClient\n\t\tpermissions = Creator.getPermissions(object_name)\n\t\tif _object.enable_audit && permissions?.modifyAllRecords\n\t\t\trelated_objects.push {object_name:\"audit_records\", foreign_key: \"related_to\"}\n\n\treturn related_objects\n\nCreator.getUserContext = (userId, spaceId, isUnSafeMode)->\n\tif Meteor.isClient\n\t\treturn Creator.USER_CONTEXT\n\telse\n\t\tif !(userId and spaceId)\n\t\t\tthrow new Meteor.Error 500, \"the params userId and spaceId is required for the function Creator.getUserContext\"\n\t\t\treturn null\n\t\tsuFields = {name: 1, mobile: 1, position: 1, email: 1, company: 1, organization: 1, space: 1, company_id: 1, company_ids: 1}\n\t\t# check if user in the space\n\t\tsu = Creator.Collections[\"space_users\"].findOne({space: spaceId, user: userId}, {fields: suFields})\n\t\tif !su\n\t\t\tspaceId = null\n\n\t\t# if spaceId not exists, get the first one.\n\t\tif !spaceId\n\t\t\tif isUnSafeMode\n\t\t\t\tsu = Creator.Collections[\"space_users\"].findOne({user: userId}, {fields: suFields})\n\t\t\t\tif !su\n\t\t\t\t\treturn null\n\t\t\t\tspaceId = su.space\n\t\t\telse\n\t\t\t\treturn null\n\n\t\tUSER_CONTEXT = {}\n\t\tUSER_CONTEXT.userId = userId\n\t\tUSER_CONTEXT.spaceId = spaceId\n\t\tUSER_CONTEXT.user = {\n\t\t\t_id: userId\n\t\t\tname: su.name,\n\t\t\tmobile: su.mobile,\n\t\t\tposition: su.position,\n\t\t\temail: su.email\n\t\t\tcompany: su.company\n\t\t\tcompany_id: su.company_id\n\t\t\tcompany_ids: su.company_ids\n\t\t}\n\t\tspace_user_org = Creator.getCollection(\"organizations\")?.findOne(su.organization)\n\t\tif space_user_org\n\t\t\tUSER_CONTEXT.user.organization = {\n\t\t\t\t_id: space_user_org._id,\n\t\t\t\tname: space_user_org.name,\n\t\t\t\tfullname: space_user_org.fullname\n\t\t\t}\n\t\treturn USER_CONTEXT\n\nCreator.getRelativeUrl = (url)->\n\n\tif _.isFunction(Steedos.isCordova) && Steedos.isCordova() && (url?.startsWith(\"/assets\") || url?.startsWith(\"assets\") || url?.startsWith(\"/packages\"))\n\t\tif !/^\\//.test(url)\n\t\t\turl = \"/\" + url\n\t\treturn url\n\n\tif url\n\t\t# url开头没有\"/\",需要添加\"/\"\n\t\tif !/^\\//.test(url)\n\t\t\turl = \"/\" + url\n\t\treturn __meteor_runtime_config__.ROOT_URL_PATH_PREFIX + url\n\telse\n\t\treturn __meteor_runtime_config__.ROOT_URL_PATH_PREFIX\n\nCreator.getUserCompanyId = (userId, spaceId)->\n\tuserId = userId || Meteor.userId()\n\tif Meteor.isClient\n\t\tspaceId = spaceId || Session.get('spaceId')\n\telse\n\t\tif !spaceId\n\t\t\tthrow new Meteor.Error(400, 'miss spaceId')\n\tsu = Creator.getCollection('space_users').findOne({space: spaceId, user: userId}, {fields: {company_id:1}})\n\treturn su.company_id\n\nCreator.getUserCompanyIds = (userId, spaceId)->\n\tuserId = userId || Meteor.userId()\n\tif Meteor.isClient\n\t\tspaceId = spaceId || Session.get('spaceId')\n\telse\n\t\tif !spaceId\n\t\t\tthrow new Meteor.Error(400, 'miss spaceId')\n\tsu = Creator.getCollection('space_users').findOne({space: spaceId, user: userId}, {fields: {company_ids:1}})\n\treturn su?.company_ids\n\nCreator.processPermissions = (po)->\n\tif po.allowCreate\n\t\tpo.allowRead = true\n\tif po.allowEdit\n\t\tpo.allowRead = true\n\tif po.allowDelete\n\t\tpo.allowEdit = true\n\t\tpo.allowRead = true\n\tif po.viewAllRecords\n\t\tpo.allowRead = true\n\tif po.modifyAllRecords\n\t\tpo.allowRead = true\n\t\tpo.allowEdit = true\n\t\tpo.allowDelete = true\n\t\tpo.viewAllRecords = true\n\tif po.viewCompanyRecords\n\t\tpo.allowRead = true\n\tif po.modifyCompanyRecords\n\t\tpo.allowRead = true\n\t\tpo.allowEdit = true\n\t\tpo.allowDelete = true\n\t\tpo.viewCompanyRecords = true\n\t\t\n\t# 如果附件相关权限配置为空,则兼容之前没有附件权限配置时的规则\n\tif po.allowRead\n\t\ttypeof po.allowReadFiles != \"boolean\" && po.allowReadFiles = true\n\t\ttypeof po.viewAllFiles != \"boolean\" && po.viewAllFiles = true\n\tif po.allowEdit\n\t\ttypeof po.allowCreateFiles != \"boolean\" && po.allowCreateFiles = true\n\t\ttypeof po.allowEditFiles != \"boolean\" && po.allowEditFiles = true\n\t\ttypeof po.allowDeleteFiles != \"boolean\" && po.allowDeleteFiles = true\n\tif po.modifyAllRecords\n\t\ttypeof po.modifyAllFiles != \"boolean\" && po.modifyAllFiles = true\n\n\tif po.allowCreateFiles\n\t\tpo.allowReadFiles = true\n\tif po.allowEditFiles\n\t\tpo.allowReadFiles = true\n\tif po.allowDeleteFiles\n\t\tpo.allowEditFiles = true\n\t\tpo.allowReadFiles = true\n\tif po.viewAllFiles\n\t\tpo.allowReadFiles = true\n\tif po.modifyAllFiles\n\t\tpo.allowReadFiles = true\n\t\tpo.allowEditFiles = true\n\t\tpo.allowDeleteFiles = true\n\t\tpo.viewAllFiles = true\n\n\treturn po\n\nCreator.getTemplateSpaceId = ()->\n\treturn Meteor.settings.public?.templateSpaceId\n\nCreator.getCloudAdminSpaceId = ()->\n\treturn Meteor.settings.public?.cloudAdminSpaceId\n\nCreator.isTemplateSpace = (spaceId)->\n\tif spaceId && Meteor.settings.public?.templateSpaceId == spaceId\n\t\treturn true\n\treturn false\n\nCreator.isCloudAdminSpace = (spaceId)->\n\tif spaceId && Meteor.settings.public?.cloudAdminSpaceId == spaceId\n\t\treturn true\n\treturn false\n\nif Meteor.isServer\n\tCreator.steedosStorageDir = process.env.STEEDOS_STORAGE_DIR\n\t","var Fiber;\n\nCreator.deps = {\n app: new Tracker.Dependency,\n object: new Tracker.Dependency\n};\n\nCreator._TEMPLATE = {\n Apps: {},\n Objects: {}\n};\n\nMeteor.startup(function() {\n SimpleSchema.extendOptions({\n filtersFunction: Match.Optional(Match.OneOf(Function, String))\n });\n SimpleSchema.extendOptions({\n optionsFunction: Match.Optional(Match.OneOf(Function, String))\n });\n return SimpleSchema.extendOptions({\n createFunction: Match.Optional(Match.OneOf(Function, String))\n });\n});\n\nif (Meteor.isServer) {\n Fiber = require('fibers');\n Creator.fiberLoadObjects = function(obj, object_name) {\n return Fiber(function() {\n return Creator.loadObjects(obj, object_name);\n }).run();\n };\n}\n\nCreator.loadObjects = function(obj, object_name) {\n if (!object_name) {\n object_name = obj.name;\n }\n if (!obj.list_views) {\n obj.list_views = {};\n }\n if (obj.space) {\n object_name = Creator.getCollectionName(obj);\n }\n if (object_name === 'cfs_files_filerecord') {\n object_name = 'cfs.files.filerecord';\n obj = _.clone(obj);\n obj.name = object_name;\n Creator.Objects[object_name] = obj;\n }\n Creator.convertObject(obj);\n new Creator.Object(obj);\n Creator.initTriggers(object_name);\n Creator.initListViews(object_name);\n return obj;\n};\n\nCreator.getObjectName = function(object) {\n if (object.space) {\n return \"c_\" + object.space + \"_\" + object.name;\n }\n return object.name;\n};\n\nCreator.getObject = function(object_name, space_id) {\n var ref, ref1;\n if (_.isArray(object_name)) {\n return;\n }\n if (Meteor.isClient) {\n if ((ref = Creator.deps) != null) {\n if ((ref1 = ref.object) != null) {\n ref1.depend();\n }\n }\n }\n if (!object_name && Meteor.isClient) {\n object_name = Session.get(\"object_name\");\n }\n if (object_name) {\n return Creator.objectsByName[object_name];\n }\n};\n\nCreator.getObjectById = function(object_id) {\n return _.findWhere(Creator.objectsByName, {\n _id: object_id\n });\n};\n\nCreator.removeObject = function(object_name) {\n console.log(\"removeObject\", object_name);\n delete Creator.Objects[object_name];\n return delete Creator.objectsByName[object_name];\n};\n\nCreator.getCollection = function(object_name, spaceId) {\n var ref;\n if (!object_name) {\n object_name = Session.get(\"object_name\");\n }\n if (object_name) {\n if (Meteor.isClient) {\n return db[object_name];\n } else {\n return Creator.Collections[((ref = Creator.getObject(object_name, spaceId)) != null ? ref._collection_name : void 0) || object_name];\n }\n }\n};\n\nCreator.removeCollection = function(object_name) {\n return delete Creator.Collections[object_name];\n};\n\nCreator.isSpaceAdmin = function(spaceId, userId) {\n var ref, ref1, space;\n if (Meteor.isClient) {\n if (!spaceId) {\n spaceId = Session.get(\"spaceId\");\n }\n if (!userId) {\n userId = Meteor.userId();\n }\n }\n space = (ref = Creator.getObject(\"spaces\")) != null ? (ref1 = ref.db) != null ? ref1.findOne(spaceId, {\n fields: {\n admins: 1\n }\n }) : void 0 : void 0;\n if (space != null ? space.admins : void 0) {\n return space.admins.indexOf(userId) >= 0;\n }\n};\n\nCreator.evaluateFormula = function(formular, context, options) {\n if (!_.isString(formular)) {\n return formular;\n }\n if (Creator.Formular.checkFormula(formular)) {\n return Creator.Formular.run(formular, context, options);\n }\n return formular;\n};\n\nCreator.evaluateFilters = function(filters, context) {\n var selector;\n selector = {};\n _.each(filters, function(filter) {\n var action, name, value;\n if ((filter != null ? filter.length : void 0) === 3) {\n name = filter[0];\n action = filter[1];\n value = Creator.evaluateFormula(filter[2], context);\n selector[name] = {};\n return selector[name][action] = value;\n }\n });\n return selector;\n};\n\nCreator.isCommonSpace = function(spaceId) {\n return spaceId === 'common';\n};\n\n\n/*\n\tdocs:待排序的文档数组\n\tids:_id集合\n\tid_key: 默认为_id\n\treturn 按照ids的顺序返回新的文档集合\n */\n\nCreator.getOrderlySetByIds = function(docs, ids, id_key, hit_first) {\n var values;\n if (!id_key) {\n id_key = \"_id\";\n }\n if (hit_first) {\n values = docs.getProperty(id_key);\n return _.sortBy(docs, function(doc) {\n var _index;\n _index = ids.indexOf(doc[id_key]);\n if (_index > -1) {\n return _index;\n } else {\n return ids.length + _.indexOf(values, doc[id_key]);\n }\n });\n } else {\n return _.sortBy(docs, function(doc) {\n var v;\n v = ids.indexOf(doc[id_key]);\n if (v < 0) {\n return 99999;\n } else {\n return v;\n }\n });\n }\n};\n\n\n/*\n\t按用户所属本地化语言进行排序,支持中文、数值、日期等字段排序\n\t对于Object类型,如果提供作用域中key属性,则取值为value[key]进行排序比较,反之整个Object.toString()后排序比较\n */\n\nCreator.sortingMethod = function(value1, value2) {\n var isValue1Empty, isValue2Empty, locale;\n if (this.key) {\n value1 = value1[this.key];\n value2 = value2[this.key];\n }\n if (value1 instanceof Date) {\n value1 = value1.getTime();\n }\n if (value2 instanceof Date) {\n value2 = value2.getTime();\n }\n if (typeof value1 === \"number\" && typeof value2 === \"number\") {\n return value1 - value2;\n }\n isValue1Empty = value1 === null || value1 === void 0;\n isValue2Empty = value2 === null || value2 === void 0;\n if (isValue1Empty && !isValue2Empty) {\n return -1;\n }\n if (isValue1Empty && isValue2Empty) {\n return 0;\n }\n if (!isValue1Empty && isValue2Empty) {\n return 1;\n }\n locale = Steedos.locale();\n return value1.toString().localeCompare(value2.toString(), locale);\n};\n\nCreator.getObjectRelateds = function(object_name) {\n var _object, permissions, relatedList, relatedListMap, related_objects;\n if (Meteor.isClient) {\n if (!object_name) {\n object_name = Session.get(\"object_name\");\n }\n }\n related_objects = [];\n _object = Creator.Objects[object_name];\n if (!_object) {\n return related_objects;\n }\n relatedList = _object.relatedList;\n if (Meteor.isClient && !_.isEmpty(relatedList)) {\n relatedListMap = {};\n _.each(relatedList, function(objName) {\n if (_.isObject(objName)) {\n return relatedListMap[objName.objectName] = {};\n } else {\n return relatedListMap[objName] = {};\n }\n });\n _.each(Creator.Objects, function(related_object, related_object_name) {\n return _.each(related_object.fields, function(related_field, related_field_name) {\n if ((related_field.type === \"master_detail\" || related_field.type === \"lookup\") && related_field.reference_to && related_field.reference_to === object_name && relatedListMap[related_object_name]) {\n if (_.isEmpty(relatedListMap[related_object_name] || related_field.type === \"master_detail\")) {\n return relatedListMap[related_object_name] = {\n object_name: related_object_name,\n foreign_key: related_field_name,\n write_requires_master_read: related_field.write_requires_master_read\n };\n }\n }\n });\n });\n if (relatedListMap['cms_files']) {\n relatedListMap['cms_files'] = {\n object_name: \"cms_files\",\n foreign_key: \"parent\"\n };\n }\n if (relatedListMap['instances']) {\n relatedListMap['instances'] = {\n object_name: \"instances\",\n foreign_key: \"record_ids\"\n };\n }\n _.each(['tasks', 'notes', 'events', 'approvals'], function(enableObjName) {\n if (relatedListMap[enableObjName]) {\n return relatedListMap[enableObjName] = {\n object_name: enableObjName,\n foreign_key: \"related_to\"\n };\n }\n });\n if (relatedListMap['audit_records']) {\n permissions = Creator.getPermissions(object_name);\n if (_object.enable_audit && (permissions != null ? permissions.modifyAllRecords : void 0)) {\n relatedListMap['audit_records'] = {\n object_name: \"audit_records\",\n foreign_key: \"related_to\"\n };\n }\n }\n related_objects = _.values(relatedListMap);\n return related_objects;\n }\n if (_object.enable_files) {\n related_objects.push({\n object_name: \"cms_files\",\n foreign_key: \"parent\"\n });\n }\n _.each(Creator.Objects, function(related_object, related_object_name) {\n var sfsFilesObject;\n if (related_object_name === \"cfs.files.filerecord\") {\n sfsFilesObject = Creator.getObject(\"cfs.files.filerecord\");\n sfsFilesObject && (related_object = sfsFilesObject);\n }\n return _.each(related_object.fields, function(related_field, related_field_name) {\n if ((related_field.type === \"master_detail\" || (related_field.type === \"lookup\" && related_field.relatedList)) && related_field.reference_to && related_field.reference_to === object_name) {\n if (related_object_name === \"object_fields\") {\n return related_objects.splice(0, 0, {\n object_name: related_object_name,\n foreign_key: related_field_name\n });\n } else {\n return related_objects.push({\n object_name: related_object_name,\n foreign_key: related_field_name,\n write_requires_master_read: related_field.write_requires_master_read\n });\n }\n }\n });\n });\n if (_object.enable_tasks) {\n related_objects.push({\n object_name: \"tasks\",\n foreign_key: \"related_to\"\n });\n }\n if (_object.enable_notes) {\n related_objects.push({\n object_name: \"notes\",\n foreign_key: \"related_to\"\n });\n }\n if (_object.enable_events) {\n related_objects.push({\n object_name: \"events\",\n foreign_key: \"related_to\"\n });\n }\n if (_object.enable_instances) {\n related_objects.push({\n object_name: \"instances\",\n foreign_key: \"record_ids\"\n });\n }\n if (_object.enable_approvals) {\n related_objects.push({\n object_name: \"approvals\",\n foreign_key: \"related_to\"\n });\n }\n if (_object.enable_process) {\n related_objects.push({\n object_name: \"process_instance_history\",\n foreign_key: \"target_object\"\n });\n }\n if (Meteor.isClient) {\n permissions = Creator.getPermissions(object_name);\n if (_object.enable_audit && (permissions != null ? permissions.modifyAllRecords : void 0)) {\n related_objects.push({\n object_name: \"audit_records\",\n foreign_key: \"related_to\"\n });\n }\n }\n return related_objects;\n};\n\nCreator.getUserContext = function(userId, spaceId, isUnSafeMode) {\n var USER_CONTEXT, ref, space_user_org, su, suFields;\n if (Meteor.isClient) {\n return Creator.USER_CONTEXT;\n } else {\n if (!(userId && spaceId)) {\n throw new Meteor.Error(500, \"the params userId and spaceId is required for the function Creator.getUserContext\");\n return null;\n }\n suFields = {\n name: 1,\n mobile: 1,\n position: 1,\n email: 1,\n company: 1,\n organization: 1,\n space: 1,\n company_id: 1,\n company_ids: 1\n };\n su = Creator.Collections[\"space_users\"].findOne({\n space: spaceId,\n user: userId\n }, {\n fields: suFields\n });\n if (!su) {\n spaceId = null;\n }\n if (!spaceId) {\n if (isUnSafeMode) {\n su = Creator.Collections[\"space_users\"].findOne({\n user: userId\n }, {\n fields: suFields\n });\n if (!su) {\n return null;\n }\n spaceId = su.space;\n } else {\n return null;\n }\n }\n USER_CONTEXT = {};\n USER_CONTEXT.userId = userId;\n USER_CONTEXT.spaceId = spaceId;\n USER_CONTEXT.user = {\n _id: userId,\n name: su.name,\n mobile: su.mobile,\n position: su.position,\n email: su.email,\n company: su.company,\n company_id: su.company_id,\n company_ids: su.company_ids\n };\n space_user_org = (ref = Creator.getCollection(\"organizations\")) != null ? ref.findOne(su.organization) : void 0;\n if (space_user_org) {\n USER_CONTEXT.user.organization = {\n _id: space_user_org._id,\n name: space_user_org.name,\n fullname: space_user_org.fullname\n };\n }\n return USER_CONTEXT;\n }\n};\n\nCreator.getRelativeUrl = function(url) {\n if (_.isFunction(Steedos.isCordova) && Steedos.isCordova() && ((url != null ? url.startsWith(\"/assets\") : void 0) || (url != null ? url.startsWith(\"assets\") : void 0) || (url != null ? url.startsWith(\"/packages\") : void 0))) {\n if (!/^\\//.test(url)) {\n url = \"/\" + url;\n }\n return url;\n }\n if (url) {\n if (!/^\\//.test(url)) {\n url = \"/\" + url;\n }\n return __meteor_runtime_config__.ROOT_URL_PATH_PREFIX + url;\n } else {\n return __meteor_runtime_config__.ROOT_URL_PATH_PREFIX;\n }\n};\n\nCreator.getUserCompanyId = function(userId, spaceId) {\n var su;\n userId = userId || Meteor.userId();\n if (Meteor.isClient) {\n spaceId = spaceId || Session.get('spaceId');\n } else {\n if (!spaceId) {\n throw new Meteor.Error(400, 'miss spaceId');\n }\n }\n su = Creator.getCollection('space_users').findOne({\n space: spaceId,\n user: userId\n }, {\n fields: {\n company_id: 1\n }\n });\n return su.company_id;\n};\n\nCreator.getUserCompanyIds = function(userId, spaceId) {\n var su;\n userId = userId || Meteor.userId();\n if (Meteor.isClient) {\n spaceId = spaceId || Session.get('spaceId');\n } else {\n if (!spaceId) {\n throw new Meteor.Error(400, 'miss spaceId');\n }\n }\n su = Creator.getCollection('space_users').findOne({\n space: spaceId,\n user: userId\n }, {\n fields: {\n company_ids: 1\n }\n });\n return su != null ? su.company_ids : void 0;\n};\n\nCreator.processPermissions = function(po) {\n if (po.allowCreate) {\n po.allowRead = true;\n }\n if (po.allowEdit) {\n po.allowRead = true;\n }\n if (po.allowDelete) {\n po.allowEdit = true;\n po.allowRead = true;\n }\n if (po.viewAllRecords) {\n po.allowRead = true;\n }\n if (po.modifyAllRecords) {\n po.allowRead = true;\n po.allowEdit = true;\n po.allowDelete = true;\n po.viewAllRecords = true;\n }\n if (po.viewCompanyRecords) {\n po.allowRead = true;\n }\n if (po.modifyCompanyRecords) {\n po.allowRead = true;\n po.allowEdit = true;\n po.allowDelete = true;\n po.viewCompanyRecords = true;\n }\n if (po.allowRead) {\n typeof po.allowReadFiles !== \"boolean\" && (po.allowReadFiles = true);\n typeof po.viewAllFiles !== \"boolean\" && (po.viewAllFiles = true);\n }\n if (po.allowEdit) {\n typeof po.allowCreateFiles !== \"boolean\" && (po.allowCreateFiles = true);\n typeof po.allowEditFiles !== \"boolean\" && (po.allowEditFiles = true);\n typeof po.allowDeleteFiles !== \"boolean\" && (po.allowDeleteFiles = true);\n }\n if (po.modifyAllRecords) {\n typeof po.modifyAllFiles !== \"boolean\" && (po.modifyAllFiles = true);\n }\n if (po.allowCreateFiles) {\n po.allowReadFiles = true;\n }\n if (po.allowEditFiles) {\n po.allowReadFiles = true;\n }\n if (po.allowDeleteFiles) {\n po.allowEditFiles = true;\n po.allowReadFiles = true;\n }\n if (po.viewAllFiles) {\n po.allowReadFiles = true;\n }\n if (po.modifyAllFiles) {\n po.allowReadFiles = true;\n po.allowEditFiles = true;\n po.allowDeleteFiles = true;\n po.viewAllFiles = true;\n }\n return po;\n};\n\nCreator.getTemplateSpaceId = function() {\n var ref;\n return (ref = Meteor.settings[\"public\"]) != null ? ref.templateSpaceId : void 0;\n};\n\nCreator.getCloudAdminSpaceId = function() {\n var ref;\n return (ref = Meteor.settings[\"public\"]) != null ? ref.cloudAdminSpaceId : void 0;\n};\n\nCreator.isTemplateSpace = function(spaceId) {\n var ref;\n if (spaceId && ((ref = Meteor.settings[\"public\"]) != null ? ref.templateSpaceId : void 0) === spaceId) {\n return true;\n }\n return false;\n};\n\nCreator.isCloudAdminSpace = function(spaceId) {\n var ref;\n if (spaceId && ((ref = Meteor.settings[\"public\"]) != null ? ref.cloudAdminSpaceId : void 0) === spaceId) {\n return true;\n }\n return false;\n};\n\nif (Meteor.isServer) {\n Creator.steedosStorageDir = process.env.STEEDOS_STORAGE_DIR;\n}\n","Meteor.methods\n\t# 用户获取lookup 、master_detail类型字段的选项值\n\t\"creator.object_options\": (options)->\n\t\tif options?.params?.reference_to\n\n\t\t\tobject = Creator.getObject(options.params.reference_to, options.params.space)\n\n\t\t\tname_field_key = object.NAME_FIELD_KEY\n\n\t\t\tquery = {}\n\t\t\tif options.params.space\n\t\t\t\tquery.space = options.params.space\n\n\t\t\t\tsort = options?.sort\n\n\t\t\t\tselected = options?.selected || []\n\n\t\t\t\toptions_limit = options?.options_limit || 10\n\n\t\t\t\tif options.searchText\n\t\t\t\t\tsearchTextQuery = {}\n\t\t\t\t\tsearchTextQuery[name_field_key] = {$regex: options.searchText}\n\n\t\t\t\tif options?.values?.length\n\t\t\t\t\tif options.searchText\n\t\t\t\t\t\tquery.$or = [{_id: {$in: options.values}}, searchTextQuery]\n\t\t\t\t\telse\n\t\t\t\t\t\tquery.$or = [{_id: {$in: options.values}}]\n\t\t\t\telse\n\t\t\t\t\tif options.searchText\n\t\t\t\t\t\t_.extend(query, searchTextQuery)\n\t\t\t\t\tquery._id = {$nin: selected}\n\n\t\t\t\tcollection = object.db\n\n\t\t\t\tif options.filterQuery\n\t\t\t\t\t_.extend query, options.filterQuery\n\n\t\t\t\tquery_options = {limit: options_limit}\n\n\t\t\t\tif sort && _.isObject(sort)\n\t\t\t\t\tquery_options.sort = sort\n\n\t\t\t\tif collection\n\t\t\t\t\ttry\n\t\t\t\t\t\trecords = collection.find(query, query_options).fetch()\n\t\t\t\t\t\tresults = []\n\t\t\t\t\t\t_.each records, (record)->\n\t\t\t\t\t\t\tresults.push\n\t\t\t\t\t\t\t\tlabel: record[name_field_key]\n\t\t\t\t\t\t\t\tvalue: record._id\n\t\t\t\t\t\treturn results\n\t\t\t\t\tcatch e\n\t\t\t\t\t\tthrow new Meteor.Error 500, e.message + \"-->\" + JSON.stringify(options)\n\t\treturn [] ","Meteor.methods({\n \"creator.object_options\": function(options) {\n var collection, e, name_field_key, object, options_limit, query, query_options, records, ref, ref1, results, searchTextQuery, selected, sort;\n if (options != null ? (ref = options.params) != null ? ref.reference_to : void 0 : void 0) {\n object = Creator.getObject(options.params.reference_to, options.params.space);\n name_field_key = object.NAME_FIELD_KEY;\n query = {};\n if (options.params.space) {\n query.space = options.params.space;\n sort = options != null ? options.sort : void 0;\n selected = (options != null ? options.selected : void 0) || [];\n options_limit = (options != null ? options.options_limit : void 0) || 10;\n if (options.searchText) {\n searchTextQuery = {};\n searchTextQuery[name_field_key] = {\n $regex: options.searchText\n };\n }\n if (options != null ? (ref1 = options.values) != null ? ref1.length : void 0 : void 0) {\n if (options.searchText) {\n query.$or = [\n {\n _id: {\n $in: options.values\n }\n }, searchTextQuery\n ];\n } else {\n query.$or = [\n {\n _id: {\n $in: options.values\n }\n }\n ];\n }\n } else {\n if (options.searchText) {\n _.extend(query, searchTextQuery);\n }\n query._id = {\n $nin: selected\n };\n }\n collection = object.db;\n if (options.filterQuery) {\n _.extend(query, options.filterQuery);\n }\n query_options = {\n limit: options_limit\n };\n if (sort && _.isObject(sort)) {\n query_options.sort = sort;\n }\n if (collection) {\n try {\n records = collection.find(query, query_options).fetch();\n results = [];\n _.each(records, function(record) {\n return results.push({\n label: record[name_field_key],\n value: record._id\n });\n });\n return results;\n } catch (error) {\n e = error;\n throw new Meteor.Error(500, e.message + \"-->\" + JSON.stringify(options));\n }\n }\n }\n }\n return [];\n }\n});\n","Creator.getInitWidthPercent = (object_name, columns) ->\n\t_schema = Creator.getSchema(object_name)?._schema\n\tcolumn_num = 0\n\tif _schema\n\t\t_.each columns, (field_name) ->\n\t\t\tfield = _.pick(_schema, field_name)\n\t\t\tis_wide = field[field_name]?.autoform?.is_wide\n\t\t\tif is_wide\n\t\t\t\tcolumn_num += 2\n\t\t\telse\n\t\t\t\tcolumn_num += 1\n\n\t\tinit_width_percent = 100 / column_num\n\t\treturn init_width_percent\n\nCreator.getFieldIsWide = (object_name, field_name) ->\n\t_schema = Creator.getSchema(object_name)._schema\n\tif _schema\n\t\tfield = _.pick(_schema, field_name)\n\t\tis_wide = field[field_name]?.autoform?.is_wide\n\t\treturn is_wide\n\nCreator.getTabularOrder = (object_name, list_view_id, columns) ->\n\tsetting = Creator.Collections?.settings?.findOne({object_name: object_name, record_id: \"object_listviews\"})\n\tobj = Creator.getObject(object_name)\n\tcolumns = _.map columns, (column)->\n\t\tfield = obj.fields[column]\n\t\tif field?.type and !field.hidden\n\t\t\treturn column\n\t\telse\n\t\t\treturn undefined\n\tcolumns = _.compact columns\n\tif setting and setting.settings\n\t\tsort = setting.settings[list_view_id]?.sort || []\n\t\tsort = _.map sort, (order)->\n\t\t\tkey = order[0]\n\t\t\tindex = _.indexOf(columns, key)\n\t\t\torder[0] = index + 1\n\t\t\treturn order\n\t\treturn sort\n\treturn []\n\n\nCreator.initListViews = (object_name)->\n\tobject = Creator.getObject(object_name)\n\tcolumns = Creator.getObjectDefaultColumns(object_name) || [\"name\"]\n\textra_columns = [\"owner\"]\n\tdefault_extra_columns = Creator.getObjectDefaultExtraColumns(object_name) || [\"owner\"]\n\tif default_extra_columns\n\t\textra_columns = _.union extra_columns, default_extra_columns\n\n\torder = Creator.getObjectDefaultSort(object_name) || []\n\tif Meteor.isClient\n\t\tCreator.TabularSelectedIds?[object_name] = []\n\nCreator.convertListView = (default_view, list_view, list_view_name)->\n\tdefault_columns = default_view?.columns\n\tdefault_mobile_columns = default_view?.mobile_columns\n\tunless list_view\n\t\treturn\n\toitem = _.clone(list_view)\n\tif !_.has(oitem, \"name\")\n\t\toitem.name = list_view_name\n\tif !oitem.columns\n\t\tif default_columns\n\t\t\toitem.columns = default_columns\n\tif !oitem.columns\n\t\toitem.columns = [\"name\"]\n\tif !oitem.mobile_columns\n\t\tif default_mobile_columns\n\t\t\toitem.mobile_columns = default_mobile_columns\n\n\tif Meteor.isClient\n\t\tif Creator.isCloudAdminSpace(Session.get(\"spaceId\")) && !_.include(oitem.columns, 'space')\n\t\t\toitem.columns.push('space')\n\n\n\tif !oitem.filter_scope\n\t\t# listview视图的filter_scope默认值改为space #131\n\t\toitem.filter_scope = \"space\"\n\n\tif !_.has(oitem, \"_id\")\n\t\toitem._id = list_view_name\n\telse\n\t\toitem.label = oitem.label || list_view.name\n\n\tif _.isString(oitem.options)\n\t\toitem.options = JSON.parse(oitem.options)\n\n\t_.forEach oitem.filters, (filter, _index)->\n\t\tif !_.isArray(filter) && _.isObject(filter)\n\t\t\tif Meteor.isServer\n\t\t\t\tif _.isFunction(filter?.value)\n\t\t\t\t\tfilter._value = filter.value.toString()\n\t\t\telse\n\t\t\t\tif _.isString(filter?._value)\n\t\t\t\t\tfilter.value = Creator.eval(\"(#{filter._value})\")\n\treturn oitem\n\n\nif Meteor.isClient\n\tCreator.getRelatedList = (object_name)->\n\t\tunless object_name\n\t\t\treturn\n\t\trelatedListObjects = {}\n\t\trelatedListNames = []\n\t\tobjectLayoutRelatedListObjects = [];\n\t\t_object = Creator.getObject(object_name)\n\t\tif _object\n\t\t\tlayoutRelatedList = _object.related_lists;\n\t\t\t# layoutRelatedList 是数组就表示配置过页面布局,就启用页面布局的相关子表。\n\t\t\tif _.isArray layoutRelatedList\n\t\t\t\t_.each layoutRelatedList, (item)->\n\t\t\t\t\treObjectName = item.related_field_fullname.split('.')[0]\n\t\t\t\t\treFieldName = item.related_field_fullname.split('.')[1]\n\t\t\t\t\twrite_requires_master_read = Creator.getObject(reObjectName)?.fields[reFieldName]?.write_requires_master_read\n\t\t\t\t\trelated =\n\t\t\t\t\t\tobject_name: reObjectName\n\t\t\t\t\t\tcolumns: item.field_names\n\t\t\t\t\t\tmobile_columns: item.field_names\n\t\t\t\t\t\tis_file: reObjectName == \"cms_files\"\n\t\t\t\t\t\tfiltersFunction: item.filters\n\t\t\t\t\t\tsort: item.sort\n\t\t\t\t\t\trelated_field_name: reFieldName\n\t\t\t\t\t\tcustomRelatedListObject: true\n\t\t\t\t\t\twrite_requires_master_read: write_requires_master_read\n\t\t\t\t\t\tlabel: item.label\n\t\t\t\t\t\tactions: item.buttons\n\t\t\t\t\t\tvisible_on: item.visible_on\n\t\t\t\t\t\tpage_size: item.page_size\n\t\t\t\t\tobjectLayoutRelatedListObjects.push(related)\n\t\t\t\treturn objectLayoutRelatedListObjects;\n\t\t\trelatedList = _object.relatedList\n\t\t\tif !_.isEmpty relatedList\n\t\t\t\t_.each relatedList, (objOrName)->\n\t\t\t\t\tif _.isObject objOrName\n\t\t\t\t\t\trelated =\n\t\t\t\t\t\t\tobject_name: objOrName.objectName\n\t\t\t\t\t\t\tcolumns: objOrName.columns\n\t\t\t\t\t\t\tmobile_columns: objOrName.mobile_columns\n\t\t\t\t\t\t\tis_file: objOrName.objectName == \"cms_files\"\n\t\t\t\t\t\t\tfiltersFunction: objOrName.filters\n\t\t\t\t\t\t\tsort: objOrName.sort\n\t\t\t\t\t\t\trelated_field_name: ''\n\t\t\t\t\t\t\tcustomRelatedListObject: true\n\t\t\t\t\t\t\tlabel: objOrName.label\n\t\t\t\t\t\t\tactions: objOrName.actions\n\t\t\t\t\t\t\tpage_size: objOrName.page_size\n\t\t\t\t\t\trelatedListObjects[objOrName.objectName] = related\n\t\t\t\t\t\trelatedListNames.push objOrName.objectName\n\t\t\t\t\telse if _.isString objOrName\n\t\t\t\t\t\trelatedListNames.push objOrName\n\n\t\tmapList = {}\n\t\trelated_objects = Creator.getRelatedObjects(object_name)\n\t\t_.each related_objects, (related_object_item) ->\n\t\t\tif !related_object_item?.object_name\n\t\t\t\treturn\n\t\t\trelated_object_name = related_object_item.object_name\n\t\t\trelated_field_name = related_object_item.foreign_key\n\t\t\twrite_requires_master_read = related_object_item.write_requires_master_read\n\t\t\trelated_object = Creator.getObject(related_object_name)\n\t\t\tunless related_object\n\t\t\t\treturn\n\t\t\tcolumns = Creator.getObjectFirstListViewColumns(related_object_name) || [\"name\"]\n\t\t\tcolumns = _.without(columns, related_field_name)\n\t\t\tmobile_columns = Creator.getObjectFirstListViewColumns(related_object_name, true) || [\"name\"]\n\t\t\tmobile_columns = _.without(mobile_columns, related_field_name)\n\n\t\t\torder = Creator.getObjectDefaultSort(related_object_name)\n\t\t\ttabular_order = Creator.transformSortToTabular(order, columns)\n\n\t\t\tif /\\w+\\.\\$\\.\\w+/g.test(related_field_name)\n\t\t\t\t# object类型带子属性的related_field_name要去掉中间的美元符号,否则显示不出字段值\n\t\t\t\trelated_field_name = related_field_name.replace(/\\$\\./,\"\")\n\t\t\trelated =\n\t\t\t\tobject_name: related_object_name\n\t\t\t\tcolumns: columns\n\t\t\t\tmobile_columns: mobile_columns\n\t\t\t\trelated_field_name: related_field_name\n\t\t\t\tis_file: related_object_name == \"cms_files\"\n\t\t\t\twrite_requires_master_read: write_requires_master_read\n\n\t\t\trelatedObject = relatedListObjects[related_object_name]\n\t\t\tif relatedObject\n\t\t\t\tif relatedObject.columns\n\t\t\t\t\trelated.columns = relatedObject.columns\n\t\t\t\tif relatedObject.mobile_columns\n\t\t\t\t\trelated.mobile_columns = relatedObject.mobile_columns\n\t\t\t\tif relatedObject.sort\n\t\t\t\t\trelated.sort = relatedObject.sort\n\t\t\t\tif relatedObject.filtersFunction\n\t\t\t\t\trelated.filtersFunction = relatedObject.filtersFunction\n\t\t\t\tif relatedObject.customRelatedListObject\n\t\t\t\t\trelated.customRelatedListObject = relatedObject.customRelatedListObject\n\t\t\t\tif relatedObject.label\n\t\t\t\t\trelated.label = relatedObject.label\n\t\t\t\tif relatedObject.page_size\n\t\t\t\t\trelated.page_size = relatedObject.page_size\n\t\t\t\tdelete relatedListObjects[related_object_name]\n\n\t\t\tmapList[related.object_name] = related\n\n\n\t\tspaceId = Session.get(\"spaceId\")\n\t\tuserId = Meteor.userId()\n\t\trelated_object_names = _.pluck(_.values(relatedListObjects), \"object_name\")\n\t\tpermissions = Creator.getPermissions(object_name, spaceId, userId)\n\t\tunrelated_objects = permissions.unrelated_objects\n\t\trelated_object_names = _.difference related_object_names, unrelated_objects\n\t\t_.each relatedListObjects, (v, related_object_name) ->\n\t\t\tisActive = related_object_names.indexOf(related_object_name) > -1\n\t\t\tallowRead = Creator.getPermissions(related_object_name, spaceId, userId)?.allowRead\n\t\t\tif isActive && allowRead\n\t\t\t\tmapList[related_object_name] = v\n\n\t\tlist = []\n\t\tif _.isEmpty relatedListNames\n\t\t\tlist = _.values mapList\n\t\telse\n\t\t\t_.each relatedListNames, (objectName) ->\n\t\t\t\tif mapList[objectName]\n\t\t\t\t\tlist.push mapList[objectName]\n\n\t\tif _.has(_object, 'allow_relatedList')\n\t\t\tlist = _.filter list, (item)->\n\t\t\t\treturn _.include(_object.allow_relatedList, item.object_name)\n\n\t\treturn list\n\nCreator.getObjectFirstListView = (object_name)->\n\treturn _.first(Creator.getListViews(object_name))\n\n### \n\t取出list_view_id对应的视图,如果不存在或者没有权限,就返回第一个视图\n\texac为true时,需要强制按list_view_id精确查找,不默认返回第一个视图\n###\nCreator.getListView = (object_name, list_view_id, exac)->\n\tif Meteor.isClient\n\t\tif !object_name\n\t\t\tobject_name = Session.get(\"object_name\")\n\t\tif !list_view_id\n\t\t\tlist_view_id = Session.get(\"list_view_id\")\n\tobject = Creator.getObject(object_name)\n\tif !object\n\t\treturn\n\tlistViews = Creator.getListViews(object_name)\n\tunless listViews?.length\n\t\treturn\n\tlist_view = _.find(listViews, (item)-> return item._id == list_view_id || item.name == list_view_id)\n\tunless list_view\n\t\t# 如果不需要强制按list_view_id精确查找,则默认返回第一个视图,反之返回空\n\t\tif exac\n\t\t\treturn\n\t\telse\n\t\t\tlist_view = listViews[0]\n\treturn list_view\n\n#获取list_view_id对应的视图是否是最近查看视图\nCreator.getListViewIsRecent = (object_name, list_view_id)->\n\tif Meteor.isClient\n\t\tif !object_name\n\t\t\tobject_name = Session.get(\"object_name\")\n\t\tif !list_view_id\n\t\t\tlist_view_id = Session.get(\"list_view_id\")\n\tif typeof(list_view_id) == \"string\"\n\t\tobject = Creator.getObject(object_name)\n\t\tif !object\n\t\t\treturn\n\t\tlistView = _.findWhere(object.list_views,{_id: list_view_id})\n\telse\n\t\tlistView = list_view_id\n\treturn listView?.name == \"recent\"\n\n\n###\n 从columns参数中过滤出用于手机端显示的columns\n\t规则:\n\t1.优先把columns中的name字段排在第一个\n\t2.最多只返回4个字段\n\t3.考虑宽字段占用整行规则条件下,最多只返回两行\n###\nCreator.pickObjectMobileColumns = (object_name, columns)->\n\tresult = []\n\tmaxRows = 2 \n\tmaxCount = maxRows * 2\n\tcount = 0\n\tobject = Creator.getObject(object_name)\n\tfields = object.fields\n\tunless object\n\t\treturn columns\n\tnameKey = object.NAME_FIELD_KEY\n\tisNameColumn = (item)->\n\t\tif _.isObject(item)\n\t\t\treturn item.field == nameKey\n\t\telse\n\t\t\treturn item == nameKey\n\tgetField = (item)->\n\t\tif _.isObject(item)\n\t\t\treturn fields[item.field]\n\t\telse\n\t\t\treturn fields[item]\n\tif nameKey\n\t\tnameColumn = columns.find (item)->\n\t\t\treturn isNameColumn(item)\n\tif nameColumn\n\t\tfield = getField(nameColumn)\n\t\titemCount = if field.is_wide then 2 else 1\n\t\tcount += itemCount\n\t\tresult.push nameColumn\n\tcolumns.forEach (item)->\n\t\tfield = getField(item)\n\t\tunless field\n\t\t\treturn\n\t\titemCount = if field.is_wide then 2 else 1\n\t\tif count < maxCount and result.length < maxCount and !isNameColumn(item)\n\t\t\tcount += itemCount\n\t\t\tif count <= maxCount\n\t\t\t\tresult.push item\n\t\n\treturn result\n\n###\n 获取默认视图\n###\nCreator.getObjectDefaultView = (object_name)->\n\tobject = Creator.getObject(object_name)\n\tif !object\n\t\tobject = Creator.Objects[object_name]\n\tif object?.list_views?.default\n\t\t#TODO 此代码只是暂时兼容以前code中定义的default视图,待code中的default清理完成后,需要删除此代码\n\t\tdefaultView = object.list_views.default\n\telse\n\t\t_.each object?.list_views, (list_view, key)->\n\t\t\tif list_view.name == \"all\" || key == \"all\"\n\t\t\t\tdefaultView = list_view\n\treturn defaultView;\n\n###\n 获取对象的列表默认显示字段\n###\nCreator.getObjectDefaultColumns = (object_name, use_mobile_columns)->\n\tdefaultView = Creator.getObjectDefaultView(object_name)\n\tcolumns = defaultView?.columns\n\tif use_mobile_columns\n\t\tif defaultView?.mobile_columns\n\t\t\tcolumns = defaultView.mobile_columns\n\t\telse if columns\n\t\t\tcolumns = Creator.pickObjectMobileColumns(object_name, columns)\n\treturn columns\n\n###\n 获取对象的列表第一个视图显示的字段\n###\nCreator.getObjectFirstListViewColumns = (object_name, use_mobile_columns)->\n\tdefaultView = Creator.getObjectFirstListView(object_name)\n\tcolumns = defaultView?.columns\n\tif use_mobile_columns\n\t\tif defaultView?.mobile_columns\n\t\t\tcolumns = defaultView.mobile_columns\n\t\telse if columns\n\t\t\tcolumns = Creator.pickObjectMobileColumns(object_name, columns)\n\treturn columns\n\n###\n\t获取对象的列表默认额外加载的字段\n###\nCreator.getObjectDefaultExtraColumns = (object_name)->\n\tdefaultView = Creator.getObjectDefaultView(object_name)\n\treturn defaultView?.extra_columns\n\n###\n\t获取对象的默认排序\n###\nCreator.getObjectDefaultSort = (object_name)->\n\tdefaultView = Creator.getObjectDefaultView(object_name)\n\tif defaultView\n\t\tif defaultView.sort\n\t\t\treturn defaultView.sort\n\t\telse\n\t\t\treturn [[\"created\", \"desc\"]]\n\n\n###\n 判断是否All view\n###\nCreator.isAllView = (list_view)->\n\treturn list_view?.name == \"all\"\n\n###\n 判断是否最近查看 view\n###\nCreator.isRecentView = (list_view)->\n\treturn list_view?.name == \"recent\"\n\n###\n 将sort转换为Tabular控件所需要的格式\n###\nCreator.transformSortToTabular = (sort, tabularColumns)->\n\ttabular_sort = []\n\t_.each sort, (item)->\n\t\tif _.isArray(item)\n\t\t\t# 兼容旧的数据格式[[\"field_name\", \"order\"]]\n\t\t\tif item.length == 1\n\t\t\t\tcolumn_index = tabularColumns.indexOf(item[0])\n\t\t\t\tif column_index > -1\n\t\t\t\t\ttabular_sort.push [column_index, \"asc\"]\n\t\t\telse if item.length == 2\n\t\t\t\tcolumn_index = tabularColumns.indexOf(item[0])\n\t\t\t\tif column_index > -1\n\t\t\t\t\ttabular_sort.push [column_index, item[1]]\n\t\telse if _.isObject(item)\n\t\t\t#新数据格式:[{field_name: , order: }]\n\t\t\tfield_name = item.field_name\n\t\t\torder = item.order\n\t\t\tif field_name && order\n\t\t\t\tcolumn_index = tabularColumns.indexOf(field_name)\n\t\t\t\tif column_index > -1\n\t\t\t\t\ttabular_sort.push [column_index, order]\n\n\treturn tabular_sort\n\n###\n 将sort转换为DevExpress控件所需要的格式\n###\nCreator.transformSortToDX = (sort)->\n\tdx_sort = []\n\t_.each sort, (item)->\n\t\tif _.isArray(item)\n\t\t\t#兼容旧格式:[[\"field_name\", \"order\"]]\n\t\t\tdx_sort.push(item)\n\t\telse if _.isObject(item)\n\t\t\t#新数据格式:[{field_name: , order: }]\n\t\t\tfield_name = item.field_name\n\t\t\torder = item.order\n\t\t\tif field_name && order\n\t\t\t\tdx_sort.push [field_name, order]\n\n\treturn dx_sort\n","Creator.getInitWidthPercent = function(object_name, columns) {\n var _schema, column_num, init_width_percent, ref;\n _schema = (ref = Creator.getSchema(object_name)) != null ? ref._schema : void 0;\n column_num = 0;\n if (_schema) {\n _.each(columns, function(field_name) {\n var field, is_wide, ref1, ref2;\n field = _.pick(_schema, field_name);\n is_wide = (ref1 = field[field_name]) != null ? (ref2 = ref1.autoform) != null ? ref2.is_wide : void 0 : void 0;\n if (is_wide) {\n return column_num += 2;\n } else {\n return column_num += 1;\n }\n });\n init_width_percent = 100 / column_num;\n return init_width_percent;\n }\n};\n\nCreator.getFieldIsWide = function(object_name, field_name) {\n var _schema, field, is_wide, ref, ref1;\n _schema = Creator.getSchema(object_name)._schema;\n if (_schema) {\n field = _.pick(_schema, field_name);\n is_wide = (ref = field[field_name]) != null ? (ref1 = ref.autoform) != null ? ref1.is_wide : void 0 : void 0;\n return is_wide;\n }\n};\n\nCreator.getTabularOrder = function(object_name, list_view_id, columns) {\n var obj, ref, ref1, ref2, setting, sort;\n setting = (ref = Creator.Collections) != null ? (ref1 = ref.settings) != null ? ref1.findOne({\n object_name: object_name,\n record_id: \"object_listviews\"\n }) : void 0 : void 0;\n obj = Creator.getObject(object_name);\n columns = _.map(columns, function(column) {\n var field;\n field = obj.fields[column];\n if ((field != null ? field.type : void 0) && !field.hidden) {\n return column;\n } else {\n return void 0;\n }\n });\n columns = _.compact(columns);\n if (setting && setting.settings) {\n sort = ((ref2 = setting.settings[list_view_id]) != null ? ref2.sort : void 0) || [];\n sort = _.map(sort, function(order) {\n var index, key;\n key = order[0];\n index = _.indexOf(columns, key);\n order[0] = index + 1;\n return order;\n });\n return sort;\n }\n return [];\n};\n\nCreator.initListViews = function(object_name) {\n var columns, default_extra_columns, extra_columns, object, order, ref;\n object = Creator.getObject(object_name);\n columns = Creator.getObjectDefaultColumns(object_name) || [\"name\"];\n extra_columns = [\"owner\"];\n default_extra_columns = Creator.getObjectDefaultExtraColumns(object_name) || [\"owner\"];\n if (default_extra_columns) {\n extra_columns = _.union(extra_columns, default_extra_columns);\n }\n order = Creator.getObjectDefaultSort(object_name) || [];\n if (Meteor.isClient) {\n return (ref = Creator.TabularSelectedIds) != null ? ref[object_name] = [] : void 0;\n }\n};\n\nCreator.convertListView = function(default_view, list_view, list_view_name) {\n var default_columns, default_mobile_columns, oitem;\n default_columns = default_view != null ? default_view.columns : void 0;\n default_mobile_columns = default_view != null ? default_view.mobile_columns : void 0;\n if (!list_view) {\n return;\n }\n oitem = _.clone(list_view);\n if (!_.has(oitem, \"name\")) {\n oitem.name = list_view_name;\n }\n if (!oitem.columns) {\n if (default_columns) {\n oitem.columns = default_columns;\n }\n }\n if (!oitem.columns) {\n oitem.columns = [\"name\"];\n }\n if (!oitem.mobile_columns) {\n if (default_mobile_columns) {\n oitem.mobile_columns = default_mobile_columns;\n }\n }\n if (Meteor.isClient) {\n if (Creator.isCloudAdminSpace(Session.get(\"spaceId\")) && !_.include(oitem.columns, 'space')) {\n oitem.columns.push('space');\n }\n }\n if (!oitem.filter_scope) {\n oitem.filter_scope = \"space\";\n }\n if (!_.has(oitem, \"_id\")) {\n oitem._id = list_view_name;\n } else {\n oitem.label = oitem.label || list_view.name;\n }\n if (_.isString(oitem.options)) {\n oitem.options = JSON.parse(oitem.options);\n }\n _.forEach(oitem.filters, function(filter, _index) {\n if (!_.isArray(filter) && _.isObject(filter)) {\n if (Meteor.isServer) {\n if (_.isFunction(filter != null ? filter.value : void 0)) {\n return filter._value = filter.value.toString();\n }\n } else {\n if (_.isString(filter != null ? filter._value : void 0)) {\n return filter.value = Creator[\"eval\"](\"(\" + filter._value + \")\");\n }\n }\n }\n });\n return oitem;\n};\n\nif (Meteor.isClient) {\n Creator.getRelatedList = function(object_name) {\n var _object, layoutRelatedList, list, mapList, objectLayoutRelatedListObjects, permissions, relatedList, relatedListNames, relatedListObjects, related_object_names, related_objects, spaceId, unrelated_objects, userId;\n if (!object_name) {\n return;\n }\n relatedListObjects = {};\n relatedListNames = [];\n objectLayoutRelatedListObjects = [];\n _object = Creator.getObject(object_name);\n if (_object) {\n layoutRelatedList = _object.related_lists;\n if (_.isArray(layoutRelatedList)) {\n _.each(layoutRelatedList, function(item) {\n var reFieldName, reObjectName, ref, ref1, related, write_requires_master_read;\n reObjectName = item.related_field_fullname.split('.')[0];\n reFieldName = item.related_field_fullname.split('.')[1];\n write_requires_master_read = (ref = Creator.getObject(reObjectName)) != null ? (ref1 = ref.fields[reFieldName]) != null ? ref1.write_requires_master_read : void 0 : void 0;\n related = {\n object_name: reObjectName,\n columns: item.field_names,\n mobile_columns: item.field_names,\n is_file: reObjectName === \"cms_files\",\n filtersFunction: item.filters,\n sort: item.sort,\n related_field_name: reFieldName,\n customRelatedListObject: true,\n write_requires_master_read: write_requires_master_read,\n label: item.label,\n actions: item.buttons,\n visible_on: item.visible_on,\n page_size: item.page_size\n };\n return objectLayoutRelatedListObjects.push(related);\n });\n return objectLayoutRelatedListObjects;\n }\n relatedList = _object.relatedList;\n if (!_.isEmpty(relatedList)) {\n _.each(relatedList, function(objOrName) {\n var related;\n if (_.isObject(objOrName)) {\n related = {\n object_name: objOrName.objectName,\n columns: objOrName.columns,\n mobile_columns: objOrName.mobile_columns,\n is_file: objOrName.objectName === \"cms_files\",\n filtersFunction: objOrName.filters,\n sort: objOrName.sort,\n related_field_name: '',\n customRelatedListObject: true,\n label: objOrName.label,\n actions: objOrName.actions,\n page_size: objOrName.page_size\n };\n relatedListObjects[objOrName.objectName] = related;\n return relatedListNames.push(objOrName.objectName);\n } else if (_.isString(objOrName)) {\n return relatedListNames.push(objOrName);\n }\n });\n }\n }\n mapList = {};\n related_objects = Creator.getRelatedObjects(object_name);\n _.each(related_objects, function(related_object_item) {\n var columns, mobile_columns, order, related, relatedObject, related_field_name, related_object, related_object_name, tabular_order, write_requires_master_read;\n if (!(related_object_item != null ? related_object_item.object_name : void 0)) {\n return;\n }\n related_object_name = related_object_item.object_name;\n related_field_name = related_object_item.foreign_key;\n write_requires_master_read = related_object_item.write_requires_master_read;\n related_object = Creator.getObject(related_object_name);\n if (!related_object) {\n return;\n }\n columns = Creator.getObjectFirstListViewColumns(related_object_name) || [\"name\"];\n columns = _.without(columns, related_field_name);\n mobile_columns = Creator.getObjectFirstListViewColumns(related_object_name, true) || [\"name\"];\n mobile_columns = _.without(mobile_columns, related_field_name);\n order = Creator.getObjectDefaultSort(related_object_name);\n tabular_order = Creator.transformSortToTabular(order, columns);\n if (/\\w+\\.\\$\\.\\w+/g.test(related_field_name)) {\n related_field_name = related_field_name.replace(/\\$\\./, \"\");\n }\n related = {\n object_name: related_object_name,\n columns: columns,\n mobile_columns: mobile_columns,\n related_field_name: related_field_name,\n is_file: related_object_name === \"cms_files\",\n write_requires_master_read: write_requires_master_read\n };\n relatedObject = relatedListObjects[related_object_name];\n if (relatedObject) {\n if (relatedObject.columns) {\n related.columns = relatedObject.columns;\n }\n if (relatedObject.mobile_columns) {\n related.mobile_columns = relatedObject.mobile_columns;\n }\n if (relatedObject.sort) {\n related.sort = relatedObject.sort;\n }\n if (relatedObject.filtersFunction) {\n related.filtersFunction = relatedObject.filtersFunction;\n }\n if (relatedObject.customRelatedListObject) {\n related.customRelatedListObject = relatedObject.customRelatedListObject;\n }\n if (relatedObject.label) {\n related.label = relatedObject.label;\n }\n if (relatedObject.page_size) {\n related.page_size = relatedObject.page_size;\n }\n delete relatedListObjects[related_object_name];\n }\n return mapList[related.object_name] = related;\n });\n spaceId = Session.get(\"spaceId\");\n userId = Meteor.userId();\n related_object_names = _.pluck(_.values(relatedListObjects), \"object_name\");\n permissions = Creator.getPermissions(object_name, spaceId, userId);\n unrelated_objects = permissions.unrelated_objects;\n related_object_names = _.difference(related_object_names, unrelated_objects);\n _.each(relatedListObjects, function(v, related_object_name) {\n var allowRead, isActive, ref;\n isActive = related_object_names.indexOf(related_object_name) > -1;\n allowRead = (ref = Creator.getPermissions(related_object_name, spaceId, userId)) != null ? ref.allowRead : void 0;\n if (isActive && allowRead) {\n return mapList[related_object_name] = v;\n }\n });\n list = [];\n if (_.isEmpty(relatedListNames)) {\n list = _.values(mapList);\n } else {\n _.each(relatedListNames, function(objectName) {\n if (mapList[objectName]) {\n return list.push(mapList[objectName]);\n }\n });\n }\n if (_.has(_object, 'allow_relatedList')) {\n list = _.filter(list, function(item) {\n return _.include(_object.allow_relatedList, item.object_name);\n });\n }\n return list;\n };\n}\n\nCreator.getObjectFirstListView = function(object_name) {\n return _.first(Creator.getListViews(object_name));\n};\n\n\n/* \n\t取出list_view_id对应的视图,如果不存在或者没有权限,就返回第一个视图\n\texac为true时,需要强制按list_view_id精确查找,不默认返回第一个视图\n */\n\nCreator.getListView = function(object_name, list_view_id, exac) {\n var listViews, list_view, object;\n if (Meteor.isClient) {\n if (!object_name) {\n object_name = Session.get(\"object_name\");\n }\n if (!list_view_id) {\n list_view_id = Session.get(\"list_view_id\");\n }\n }\n object = Creator.getObject(object_name);\n if (!object) {\n return;\n }\n listViews = Creator.getListViews(object_name);\n if (!(listViews != null ? listViews.length : void 0)) {\n return;\n }\n list_view = _.find(listViews, function(item) {\n return item._id === list_view_id || item.name === list_view_id;\n });\n if (!list_view) {\n if (exac) {\n return;\n } else {\n list_view = listViews[0];\n }\n }\n return list_view;\n};\n\nCreator.getListViewIsRecent = function(object_name, list_view_id) {\n var listView, object;\n if (Meteor.isClient) {\n if (!object_name) {\n object_name = Session.get(\"object_name\");\n }\n if (!list_view_id) {\n list_view_id = Session.get(\"list_view_id\");\n }\n }\n if (typeof list_view_id === \"string\") {\n object = Creator.getObject(object_name);\n if (!object) {\n return;\n }\n listView = _.findWhere(object.list_views, {\n _id: list_view_id\n });\n } else {\n listView = list_view_id;\n }\n return (listView != null ? listView.name : void 0) === \"recent\";\n};\n\n\n/*\n 从columns参数中过滤出用于手机端显示的columns\n\t规则:\n\t1.优先把columns中的name字段排在第一个\n\t2.最多只返回4个字段\n\t3.考虑宽字段占用整行规则条件下,最多只返回两行\n */\n\nCreator.pickObjectMobileColumns = function(object_name, columns) {\n var count, field, fields, getField, isNameColumn, itemCount, maxCount, maxRows, nameColumn, nameKey, object, result;\n result = [];\n maxRows = 2;\n maxCount = maxRows * 2;\n count = 0;\n object = Creator.getObject(object_name);\n fields = object.fields;\n if (!object) {\n return columns;\n }\n nameKey = object.NAME_FIELD_KEY;\n isNameColumn = function(item) {\n if (_.isObject(item)) {\n return item.field === nameKey;\n } else {\n return item === nameKey;\n }\n };\n getField = function(item) {\n if (_.isObject(item)) {\n return fields[item.field];\n } else {\n return fields[item];\n }\n };\n if (nameKey) {\n nameColumn = columns.find(function(item) {\n return isNameColumn(item);\n });\n }\n if (nameColumn) {\n field = getField(nameColumn);\n itemCount = field.is_wide ? 2 : 1;\n count += itemCount;\n result.push(nameColumn);\n }\n columns.forEach(function(item) {\n field = getField(item);\n if (!field) {\n return;\n }\n itemCount = field.is_wide ? 2 : 1;\n if (count < maxCount && result.length < maxCount && !isNameColumn(item)) {\n count += itemCount;\n if (count <= maxCount) {\n return result.push(item);\n }\n }\n });\n return result;\n};\n\n\n/*\n 获取默认视图\n */\n\nCreator.getObjectDefaultView = function(object_name) {\n var defaultView, object, ref;\n object = Creator.getObject(object_name);\n if (!object) {\n object = Creator.Objects[object_name];\n }\n if (object != null ? (ref = object.list_views) != null ? ref[\"default\"] : void 0 : void 0) {\n defaultView = object.list_views[\"default\"];\n } else {\n _.each(object != null ? object.list_views : void 0, function(list_view, key) {\n if (list_view.name === \"all\" || key === \"all\") {\n return defaultView = list_view;\n }\n });\n }\n return defaultView;\n};\n\n\n/*\n 获取对象的列表默认显示字段\n */\n\nCreator.getObjectDefaultColumns = function(object_name, use_mobile_columns) {\n var columns, defaultView;\n defaultView = Creator.getObjectDefaultView(object_name);\n columns = defaultView != null ? defaultView.columns : void 0;\n if (use_mobile_columns) {\n if (defaultView != null ? defaultView.mobile_columns : void 0) {\n columns = defaultView.mobile_columns;\n } else if (columns) {\n columns = Creator.pickObjectMobileColumns(object_name, columns);\n }\n }\n return columns;\n};\n\n\n/*\n 获取对象的列表第一个视图显示的字段\n */\n\nCreator.getObjectFirstListViewColumns = function(object_name, use_mobile_columns) {\n var columns, defaultView;\n defaultView = Creator.getObjectFirstListView(object_name);\n columns = defaultView != null ? defaultView.columns : void 0;\n if (use_mobile_columns) {\n if (defaultView != null ? defaultView.mobile_columns : void 0) {\n columns = defaultView.mobile_columns;\n } else if (columns) {\n columns = Creator.pickObjectMobileColumns(object_name, columns);\n }\n }\n return columns;\n};\n\n\n/*\n\t获取对象的列表默认额外加载的字段\n */\n\nCreator.getObjectDefaultExtraColumns = function(object_name) {\n var defaultView;\n defaultView = Creator.getObjectDefaultView(object_name);\n return defaultView != null ? defaultView.extra_columns : void 0;\n};\n\n\n/*\n\t获取对象的默认排序\n */\n\nCreator.getObjectDefaultSort = function(object_name) {\n var defaultView;\n defaultView = Creator.getObjectDefaultView(object_name);\n if (defaultView) {\n if (defaultView.sort) {\n return defaultView.sort;\n } else {\n return [[\"created\", \"desc\"]];\n }\n }\n};\n\n\n/*\n 判断是否All view\n */\n\nCreator.isAllView = function(list_view) {\n return (list_view != null ? list_view.name : void 0) === \"all\";\n};\n\n\n/*\n 判断是否最近查看 view\n */\n\nCreator.isRecentView = function(list_view) {\n return (list_view != null ? list_view.name : void 0) === \"recent\";\n};\n\n\n/*\n 将sort转换为Tabular控件所需要的格式\n */\n\nCreator.transformSortToTabular = function(sort, tabularColumns) {\n var tabular_sort;\n tabular_sort = [];\n _.each(sort, function(item) {\n var column_index, field_name, order;\n if (_.isArray(item)) {\n if (item.length === 1) {\n column_index = tabularColumns.indexOf(item[0]);\n if (column_index > -1) {\n return tabular_sort.push([column_index, \"asc\"]);\n }\n } else if (item.length === 2) {\n column_index = tabularColumns.indexOf(item[0]);\n if (column_index > -1) {\n return tabular_sort.push([column_index, item[1]]);\n }\n }\n } else if (_.isObject(item)) {\n field_name = item.field_name;\n order = item.order;\n if (field_name && order) {\n column_index = tabularColumns.indexOf(field_name);\n if (column_index > -1) {\n return tabular_sort.push([column_index, order]);\n }\n }\n }\n });\n return tabular_sort;\n};\n\n\n/*\n 将sort转换为DevExpress控件所需要的格式\n */\n\nCreator.transformSortToDX = function(sort) {\n var dx_sort;\n dx_sort = [];\n _.each(sort, function(item) {\n var field_name, order;\n if (_.isArray(item)) {\n return dx_sort.push(item);\n } else if (_.isObject(item)) {\n field_name = item.field_name;\n order = item.order;\n if (field_name && order) {\n return dx_sort.push([field_name, order]);\n }\n }\n });\n return dx_sort;\n};\n","SimpleSchema.RegEx.code = new RegExp('^[a-zA-Z_][a-zA-Z0-9_]*$')\n\nif Meteor.isClient\n\tMeteor.startup ()->\n\t\t_regExMessages = SimpleSchema._globalMessages.regEx || []\n\t\t_regExMessages.push {exp: SimpleSchema.RegEx.code, msg: \"[label] 只能以字母、_开头,且只能包含字母、数字、_\"}\n\t\tSimpleSchema.messages({\n\t\t\tregEx: _regExMessages,\n\t\t})","SimpleSchema.RegEx.code = new RegExp('^[a-zA-Z_][a-zA-Z0-9_]*$');\n\nif (Meteor.isClient) {\n Meteor.startup(function() {\n var _regExMessages;\n _regExMessages = SimpleSchema._globalMessages.regEx || [];\n _regExMessages.push({\n exp: SimpleSchema.RegEx.code,\n msg: \"[label] 只能以字母、_开头,且只能包含字母、数字、_\"\n });\n return SimpleSchema.messages({\n regEx: _regExMessages\n });\n });\n}\n","SimpleSchema.RegEx.field = new RegExp('^[a-zA-Z_]\\\\w*(\\\\.\\\\$\\\\.\\\\w+)?[a-zA-Z0-9]*$')\n\nif Meteor.isClient\n\tMeteor.startup ()->\n\t\t_regExMessages = SimpleSchema._globalMessages.regEx || []\n\t\t_regExMessages.push {exp: SimpleSchema.RegEx.field, msg: \"[label] 只能以字母、_开头,.$.前后必须包含字符\"}\n\t\tSimpleSchema.messages({\n\t\t\tregEx: _regExMessages,\n\t\t})","SimpleSchema.RegEx.field = new RegExp('^[a-zA-Z_]\\\\w*(\\\\.\\\\$\\\\.\\\\w+)?[a-zA-Z0-9]*$');\n\nif (Meteor.isClient) {\n Meteor.startup(function() {\n var _regExMessages;\n _regExMessages = SimpleSchema._globalMessages.regEx || [];\n _regExMessages.push({\n exp: SimpleSchema.RegEx.field,\n msg: \"[label] 只能以字母、_开头,.$.前后必须包含字符\"\n });\n return SimpleSchema.messages({\n regEx: _regExMessages\n });\n });\n}\n","// 因为meteor编译coffeescript会导致eval函数报错,所以单独写在一个js文件中。\nCreator.evalInContext = function(js, context) {\n //# Return the results of the in-line anonymous function we .call with the passed context\n return function() { \n \treturn eval(js); \n\t}.call(context);\n}\n\n\nCreator.eval = function(js){\n\ttry{\n\t\treturn eval(js)\n\t}catch (e){\n\t\tconsole.error(e, js);\n\t}\n};","\tgetOption = (option)->\n\t\tfoo = option.split(\":\")\n\t\tif foo.length > 2\n\t\t\treturn {label: foo[0], value: foo[1], color: foo[2]}\n\t\telse if foo.length > 1\n\t\t\treturn {label: foo[0], value: foo[1]}\n\t\telse\n\t\t\treturn {label: foo[0], value: foo[0]}\n\n\tconvertField = (object_name, field_name, field, spaceId)->\n\t\tif Meteor.isServer && spaceId && field.type == 'select'\n\t\t\tcode = field.picklist || \"#{object_name}.#{field_name}\";\n\t\t\tif code\n\t\t\t\tpicklist = Creator.getPicklist(code, spaceId);\n\t\t\t\tif picklist\n\t\t\t\t\toptions = [];\n\t\t\t\t\tallOptions = [];\n\t\t\t\t\tpicklistOptions = Creator.getPickListOptions(picklist)\n\t\t\t\t\tpicklistOptions = _.sortBy(picklistOptions, 'sort_no')?.reverse();\n\t\t\t\t\t_.each picklistOptions, (item)->\n\t\t\t\t\t\tlabel = item.name\n\t\t\t\t\t\tvalue = item.value || item.name\n\t\t\t\t\t\tallOptions.push({label: label, value: value, enable: item.enable, color: item.color})\n\t\t\t\t\t\tif item.enable\n\t\t\t\t\t\t\toptions.push({label: label, value: value, color: item.color})\n\t\t\t\t\t\tif item.default\n\t\t\t\t\t\t\tfield.defaultValue = value\n\t\t\t\t\tif options.length > 0\n\t\t\t\t\t\tfield.options = options\n\t\t\t\t\tif allOptions.length > 0\n\t\t\t\t\t\tfield.allOptions = allOptions\n\t\treturn field;\n\n\tCreator.convertObject = (object, spaceId)->\n\t\tif !object\n\t\t\treturn\n\t\t_.forEach object.triggers, (trigger, key)->\n\n\t\t\tif (Meteor.isServer && trigger.on == \"server\") || (Meteor.isClient && trigger.on == \"client\")\n\t\t\t\t_todo_from_code = trigger?._todo\n\t\t\t\t_todo_from_db = trigger.todo\n\t\t\t\tif _todo_from_code && _.isString(_todo_from_code)\n\t\t\t\t\ttrigger.todo = Creator.eval(\"(#{_todo_from_code})\")\n\n\t\t\t\tif _todo_from_db && _.isString(_todo_from_db)\n\t\t\t\t\t#只有update时, fieldNames, modifier, options 才有值\n\t\t\t\t\t#TODO 控制可使用的变量,尤其是Collection\n\t\t\t\t\tif _todo_from_db.startsWith(\"function\")\n\t\t\t\t\t\ttrigger.todo = Creator.eval(\"(#{_todo_from_db})\")\n\t\t\t\t\telse\n\t\t\t\t\t\ttrigger.todo = Creator.eval(\"(function(userId, doc, fieldNames, modifier, options){#{_todo_from_db}})\")\n\n\t\t\tif Meteor.isServer && trigger.on == \"client\"\n\t\t\t\t_todo = trigger.todo\n\t\t\t\tif _todo && _.isFunction(_todo)\n\t\t\t\t\ttrigger._todo = _todo.toString()\n\n\t\tif Meteor.isClient\n\t\t\t_.forEach object.fields, (field, key)->\n\n\t\t\t\tif field.omit\n\t\t\t\t\t# omit字段完全隐藏不显示\n\t\t\t\t\tfield.hidden = true\n\n\t\t\t\tif field.required && field.readonly\n\t\t\t\t\t# 通用必填字段 #2952,必填字段设置为非只读\n\t\t\t\t\tfield.readonly = false\n\n\t\t\t\tsystemBaseFields = Creator.getSystemBaseFields()\n\t\t\t\tif systemBaseFields.indexOf(key) > -1\n\t\t\t\t\t# 强制创建人创建时间等字段为只读\n\t\t\t\t\tfield.readonly = true\n\n\t\t\t_.forEach object.actions, (action, key)->\n\t\t\t\t_todo_from_code = action?._todo\n\t\t\t\t_todo_from_db = action?.todo\n\t\t\t\tif _todo_from_code && _.isString(_todo_from_code)\n\t\t\t\t\t#TODO 控制可使用的变量\n\t\t\t\t\ttry\n\t\t\t\t\t\taction.todo = Creator.eval(\"(#{_todo_from_code})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"todo_from_code\", _todo_from_code\n\t\t\t\tif _todo_from_db && _.isString(_todo_from_db)\n\t\t\t\t\t#TODO 控制可使用的变量\n\t\t\t\t\ttry\n\t\t\t\t\t\tif _todo_from_db.startsWith(\"function\")\n\t\t\t\t\t\t\taction.todo = Creator.eval(\"(#{_todo_from_db})\")\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tif _.isFunction(Creator.actionsByName[_todo_from_db])\n\t\t\t\t\t\t\t\taction.todo = _todo_from_db\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\taction.todo = Creator.eval(\"(function(){#{_todo_from_db}})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"todo_from_db\", _todo_from_db, error\n\n\t\t\t\t_visible = action?._visible\n\t\t\t\tif _visible\n\t\t\t\t\ttry\n\t\t\t\t\t\tif _.isString(_visible)\n\t\t\t\t\t\t\t_visible = _visible.trim()\n\t\t\t\t\t\tif Steedos.isExpression(_visible)\n\t\t\t\t\t\t\t# 支持页面布局中写visible_on函数表达式,页面布局按钮的显示条件不生效 #3340\n\t\t\t\t\t\t\taction.visible = (object_name, record_id, record_permissions, record) ->\n\t\t\t\t\t\t\t\tglobalData = Object.assign({}, Creator.USER_CONTEXT, {now: new Date()})\n\t\t\t\t\t\t\t\treturn Steedos.parseSingleExpression(_visible, record, \"#\", globalData)\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\taction.visible = Creator.eval(\"(#{_visible})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"action.visible to function error: \", error, _visible\n\t\telse\n\t\t\t_.forEach object.actions, (action, key)->\n\t\t\t\t_todo = action?.todo\n\t\t\t\tif _todo && _.isFunction(_todo)\n\t\t\t\t\t#TODO 控制可使用的变量\n\t\t\t\t\taction._todo = _todo.toString()\n\n\t\t\t\t_visible = action?.visible\n\n\t\t\t\tif _visible && _.isFunction(_visible)\n\t\t\t\t\taction._visible = _visible.toString()\n\n\t\t_.forEach object.fields, (field, key)->\n\n\t\t\tfield = convertField(object.name, key, field, spaceId);\n\n\t\t\tif field.options && _.isString(field.options)\n\t\t\t\ttry\n\t\t\t\t\t_options = []\n\t\t\t\t\t#支持\\n或者英文逗号分割,\n\t\t\t\t\t_.forEach field.options.split(\"\\n\"), (option)->\n\t\t\t\t\t\tif option.indexOf(\",\")\n\t\t\t\t\t\t\toptions = option.split(\",\")\n\t\t\t\t\t\t\t_.forEach options, (_option)->\n\t\t\t\t\t\t\t\t_options.push(getOption(_option))\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t_options.push(getOption(option))\n\t\t\t\t\tfield.options = _options\n\t\t\t\tcatch error\n\t\t\t\t\tconsole.error \"Creator.convertFieldsOptions\", field.options, error\n\n\t\t\telse if field.options && _.isArray(field.options)\n\t\t\t\ttry\n\t\t\t\t\t_options = []\n\t\t\t\t\t#支持数组中直接定义每个选项的简版格式字符串\n\t\t\t\t\t_.forEach field.options, (option)->\n\t\t\t\t\t\tif _.isString(option)\n\t\t\t\t\t\t\t_options.push(getOption(option))\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t_options.push(option)\n\t\t\t\t\tfield.options = _options\n\t\t\t\tcatch error\n\t\t\t\t\tconsole.error \"Creator.convertFieldsOptions\", field.options, error\n\n\t\t\telse if field.options && !_.isFunction(field.options) && !_.isArray(field.options) && _.isObject(field.options)\n\t\t\t\t_options = []\n\t\t\t\t_.each field.options, (v, k)->\n\t\t\t\t\t_options.push {label: v, value: k}\n\t\t\t\tfield.options = _options\n\n\t\t\tif Meteor.isServer\n\t\t\t\toptions = field.options\n\t\t\t\tif options && _.isFunction(options)\n\t\t\t\t\tfield._options = field.options.toString()\n\t\t\telse\n\t\t\t\toptions = field._options\n\t\t\t\tif options && _.isString(options)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.options = Creator.eval(\"(#{options})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t\tif Meteor.isServer\n\t\t\t\tregEx = field.regEx\n\t\t\t\tif regEx\n\t\t\t\t\tfield._regEx = field.regEx.toString()\n\t\t\telse\n\t\t\t\tregEx = field._regEx\n\t\t\t\tif regEx\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.regEx = Creator.eval(\"(#{regEx})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t\tif Meteor.isServer\n\t\t\t\tmin = field.min\n\t\t\t\tif _.isFunction(min)\n\t\t\t\t\tfield._min = min.toString()\n\t\t\telse\n\t\t\t\tmin = field._min\n\t\t\t\tif _.isString(min)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.min = Creator.eval(\"(#{min})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t\tif Meteor.isServer\n\t\t\t\tmax = field.max\n\t\t\t\tif _.isFunction(max)\n\t\t\t\t\tfield._max = max.toString()\n\t\t\telse\n\t\t\t\tmax = field._max\n\t\t\t\tif _.isString(max)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.max = Creator.eval(\"(#{max})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t\tif Meteor.isServer\n\t\t\t\tif field.autoform\n\t\t\t\t\t_type = field.autoform.type\n\t\t\t\t\tif _type && _.isFunction(_type) && _type != Object && _type != String && _type != Number && _type != Boolean && !_.isArray(_type)\n\t\t\t\t\t\tfield.autoform._type = _type.toString()\n\t\t\telse\n\t\t\t\tif field.autoform\n\t\t\t\t\t_type = field.autoform._type\n\t\t\t\t\tif _type && _.isString(_type)\n\t\t\t\t\t\ttry\n\t\t\t\t\t\t\tfield.autoform.type = Creator.eval(\"(#{_type})\")\n\t\t\t\t\t\tcatch error\n\t\t\t\t\t\t\tconsole.error \"convert field -> type error\", field, error\n\n\t\t\tif Meteor.isServer\n\n\t\t\t\toptionsFunction = field.optionsFunction\n\t\t\t\treference_to = field.reference_to\n\t\t\t\tcreateFunction = field.createFunction\n\t\t\t\tbeforeOpenFunction = field.beforeOpenFunction\n\t\t\t\tfiltersFunction = field.filtersFunction\n\n\t\t\t\tif optionsFunction && _.isFunction(optionsFunction)\n\t\t\t\t\tfield._optionsFunction = optionsFunction.toString()\n\n\t\t\t\tif reference_to && _.isFunction(reference_to)\n\t\t\t\t\tfield._reference_to = reference_to.toString()\n\n\t\t\t\tif createFunction && _.isFunction(createFunction)\n\t\t\t\t\tfield._createFunction = createFunction.toString()\n\t\t\t\tif beforeOpenFunction && _.isFunction(beforeOpenFunction)\n\t\t\t\t\tfield._beforeOpenFunction = beforeOpenFunction.toString()\n\n\t\t\t\tif filtersFunction && _.isFunction(filtersFunction)\n\t\t\t\t\tfield._filtersFunction = filtersFunction.toString()\n\t\t\telse\n\n\t\t\t\toptionsFunction = field._optionsFunction || field.optionsFunction\n\t\t\t\treference_to = field._reference_to\n\t\t\t\tcreateFunction = field._createFunction\n\t\t\t\tbeforeOpenFunction = field._beforeOpenFunction\n\t\t\t\tfiltersFunction = field._filtersFunction || field.filtersFunction\n\n\t\t\t\tif optionsFunction && _.isString(optionsFunction)\n\t\t\t\t\tfield.optionsFunction = Creator.eval(\"(#{optionsFunction})\")\n\n\t\t\t\tif reference_to && _.isString(reference_to)\n\t\t\t\t\tfield.reference_to = Creator.eval(\"(#{reference_to})\")\n\n\t\t\t\tif createFunction && _.isString(createFunction)\n\t\t\t\t\tfield.createFunction = Creator.eval(\"(#{createFunction})\")\n\n\t\t\t\tif beforeOpenFunction && _.isString(beforeOpenFunction)\n\t\t\t\t\tfield.beforeOpenFunction = Creator.eval(\"(#{beforeOpenFunction})\")\n\n\t\t\t\tif filtersFunction && _.isString(filtersFunction)\n\t\t\t\t\tfield.filtersFunction = Creator.eval(\"(#{filtersFunction})\")\n\n\t\t\tif Meteor.isServer\n\t\t\t\tdefaultValue = field.defaultValue\n\t\t\t\tif defaultValue && _.isFunction(defaultValue)\n\t\t\t\t\tfield._defaultValue = field.defaultValue.toString()\n\t\t\telse\n\t\t\t\tdefaultValue = field._defaultValue\n\n\t\t\t\tif !defaultValue && _.isString(field.defaultValue) && field.defaultValue.startsWith(\"function\")\n\t\t\t\t\tdefaultValue = field.defaultValue\n\n\t\t\t\tif defaultValue && _.isString(defaultValue)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.defaultValue = Creator.eval(\"(#{defaultValue})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\t\t\t\n\t\t\tif Meteor.isServer\n\t\t\t\tis_company_limited = field.is_company_limited\n\t\t\t\tif is_company_limited && _.isFunction(is_company_limited)\n\t\t\t\t\tfield._is_company_limited = field.is_company_limited.toString()\n\t\t\telse\n\t\t\t\tis_company_limited = field._is_company_limited\n\t\t\t\tif is_company_limited && _.isString(is_company_limited)\n\t\t\t\t\ttry\n\t\t\t\t\t\tfield.is_company_limited = Creator.eval(\"(#{is_company_limited})\")\n\t\t\t\t\tcatch error\n\t\t\t\t\t\tconsole.error \"convert error #{object.name} -> #{field.name}\", error\n\n\t\t_.forEach object.list_views, (list_view, key) ->\n\t\t\t###\n\t\t\t视图过虑器需要支持function,后台转成字符串,前台eval成函数\n\t\t\t让过虑器支持两种function方式:\n\t\t\t1. 整个filters为function:\n\t\t\t如:\n\t\t\tfilters: ()->\n\t\t\t\treturn [[[\"object_name\",\"=\",\"project_issues\"],'or',[\"object_name\",\"=\",\"tasks\"]]]\n\t\t\t2. filters内的filter.value为function\n\t\t\t如:\n\t\t\tfilters: [[\"object_name\", \"=\", ()->\n\t\t\t\treturn \"project_issues\"\n\t\t\t]]\n\t\t\t或\n\t\t\tfilters: [{\n\t\t\t\t\"field\": \"object_name\"\n\t\t\t\t\"operation\": \"=\"\n\t\t\t\t\"value\": ()->\n\t\t\t\t\treturn \"project_issues\"\n\t\t\t}]\n\t\t\t###\n\t\t\tif _.isFunction(list_view.filters)\n\t\t\t\tif Meteor.isServer\n\t\t\t\t\tlist_view._filters = list_view.filters.toString()\n\t\t\telse if _.isString(list_view._filters)\n\t\t\t\tif Meteor.isClient\n\t\t\t\t\tlist_view.filters = Creator.eval(\"(#{list_view._filters})\")\n\t\t\telse\n\t\t\t\t_.forEach list_view.filters, (filter, _index)->\n\t\t\t\t\tif _.isArray(filter)\n\t\t\t\t\t\tif Meteor.isServer\n\t\t\t\t\t\t\tif filter.length == 3 and _.isFunction(filter[2])\n\t\t\t\t\t\t\t\tfilter[2] = filter[2].toString()\n\t\t\t\t\t\t\t\tfilter[3] = \"FUNCTION\"\n\t\t\t\t\t\t\telse if filter.length == 3 and _.isDate(filter[2])\n\t\t\t\t\t\t\t\t# 如果是Date类型,则filter[2]值到前端会自动转成字符串,格式:\"2018-03-29T03:43:21.787Z\"\n\t\t\t\t\t\t\t\t# 包括grid列表请求的接口在内的所有OData接口,Date类型字段都会以上述格式返回\n\t\t\t\t\t\t\t\tfilter[3] = \"DATE\"\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tif filter.length == 4 and _.isString(filter[2]) and filter[3] == \"FUNCTION\"\n\t\t\t\t\t\t\t\tfilter[2] = Creator.eval(\"(#{filter[2]})\")\n\t\t\t\t\t\t\t\tfilter.pop()\n\t\t\t\t\t\t\tif filter.length == 4 and _.isString(filter[2]) and filter[3] == \"DATE\"\n\t\t\t\t\t\t\t\tfilter[2] = new Date(filter[2])\n\t\t\t\t\t\t\t\tfilter.pop()\n\t\t\t\t\telse if _.isObject(filter)\n\t\t\t\t\t\tif Meteor.isServer\n\t\t\t\t\t\t\tif _.isFunction(filter?.value)\n\t\t\t\t\t\t\t\tfilter._value = filter.value.toString()\n\t\t\t\t\t\t\telse if _.isDate(filter?.value)\n\t\t\t\t\t\t\t\tfilter._is_date = true\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tif _.isString(filter?._value)\n\t\t\t\t\t\t\t\tfilter.value = Creator.eval(\"(#{filter._value})\")\n\t\t\t\t\t\t\telse if filter._is_date == true\n\t\t\t\t\t\t\t\tfilter.value = new Date(filter.value)\n\n\t\tif Meteor.isServer\n\t\t\tif object.form && !_.isString(object.form)\n\t\t\t\tobject.form = JSON.stringify object.form, (key, val)->\n\t\t\t\t\tif _.isFunction(val)\n\t\t\t\t\t\treturn val + '';\n\t\t\t\t\telse\n\t\t\t\t\t\treturn val;\n\t\telse if Meteor.isClient\n\t\t\tif object.form\n\t\t\t\tobject.form = JSON.parse object.form, (key, val)->\n\t\t\t\t\tif _.isString(val) && val.startsWith('function')\n\t\t\t\t\t\treturn Creator.eval(\"(#{val})\")\n\t\t\t\t\telse\n\t\t\t\t\t\treturn val;\n\n\t\tif Meteor.isClient\n\t\t\t_.forEach object.related_lists, (relatedObjInfo)->\n\t\t\t\tif _.isObject(relatedObjInfo)\n\t\t\t\t\t_.forEach relatedObjInfo, (val, key)->\n\t\t\t\t\t\tif key == 'filters' && _.isString(val)\n\t\t\t\t\t\t\ttry\n\t\t\t\t\t\t\t\trelatedObjInfo[key] = Creator.eval(\"(#{val})\")\n\t\t\t\t\t\t\tcatch error\n\t\t\t\t\t\t\t\tconsole.error \"filters_code\", val\n\t\telse\n\t\t\t_.forEach object.related_lists, (relatedObjInfo)->\n\t\t\t\tif _.isObject(relatedObjInfo)\n\t\t\t\t\t_.forEach relatedObjInfo, (val, key)->\n\t\t\t\t\t\tif key == 'filters' && _.isFunction(val)\n\t\t\t\t\t\t\trelatedObjInfo[key] = val.toString()\n\n\t\tif Meteor.isClient\n\t\t\t_.forEach object.relatedList, (relatedObjInfo)->\n\t\t\t\tif _.isObject(relatedObjInfo)\n\t\t\t\t\t_.forEach relatedObjInfo, (val, key)->\n\t\t\t\t\t\tif key == 'filters' && _.isString(val)\n\t\t\t\t\t\t\ttry\n\t\t\t\t\t\t\t\trelatedObjInfo[key] = Creator.eval(\"(#{val})\")\n\t\t\t\t\t\t\tcatch error\n\t\t\t\t\t\t\t\tconsole.error \"filters_code\", val\n\t\telse\n\t\t\t_.forEach object.relatedList, (relatedObjInfo)->\n\t\t\t\tif _.isObject(relatedObjInfo)\n\t\t\t\t\t_.forEach relatedObjInfo, (val, key)->\n\t\t\t\t\t\tif key == 'filters' && _.isFunction(val)\n\t\t\t\t\t\t\trelatedObjInfo[key] = val.toString()\n\n\t\treturn object\n\n\n","var convertField, getOption;\n\ngetOption = function(option) {\n var foo;\n foo = option.split(\":\");\n if (foo.length > 2) {\n return {\n label: foo[0],\n value: foo[1],\n color: foo[2]\n };\n } else if (foo.length > 1) {\n return {\n label: foo[0],\n value: foo[1]\n };\n } else {\n return {\n label: foo[0],\n value: foo[0]\n };\n }\n};\n\nconvertField = function(object_name, field_name, field, spaceId) {\n var allOptions, code, options, picklist, picklistOptions, ref;\n if (Meteor.isServer && spaceId && field.type === 'select') {\n code = field.picklist || (object_name + \".\" + field_name);\n if (code) {\n picklist = Creator.getPicklist(code, spaceId);\n if (picklist) {\n options = [];\n allOptions = [];\n picklistOptions = Creator.getPickListOptions(picklist);\n picklistOptions = (ref = _.sortBy(picklistOptions, 'sort_no')) != null ? ref.reverse() : void 0;\n _.each(picklistOptions, function(item) {\n var label, value;\n label = item.name;\n value = item.value || item.name;\n allOptions.push({\n label: label,\n value: value,\n enable: item.enable,\n color: item.color\n });\n if (item.enable) {\n options.push({\n label: label,\n value: value,\n color: item.color\n });\n }\n if (item[\"default\"]) {\n return field.defaultValue = value;\n }\n });\n if (options.length > 0) {\n field.options = options;\n }\n if (allOptions.length > 0) {\n field.allOptions = allOptions;\n }\n }\n }\n }\n return field;\n};\n\nCreator.convertObject = function(object, spaceId) {\n if (!object) {\n return;\n }\n _.forEach(object.triggers, function(trigger, key) {\n var _todo, _todo_from_code, _todo_from_db;\n if ((Meteor.isServer && trigger.on === \"server\") || (Meteor.isClient && trigger.on === \"client\")) {\n _todo_from_code = trigger != null ? trigger._todo : void 0;\n _todo_from_db = trigger.todo;\n if (_todo_from_code && _.isString(_todo_from_code)) {\n trigger.todo = Creator[\"eval\"](\"(\" + _todo_from_code + \")\");\n }\n if (_todo_from_db && _.isString(_todo_from_db)) {\n if (_todo_from_db.startsWith(\"function\")) {\n trigger.todo = Creator[\"eval\"](\"(\" + _todo_from_db + \")\");\n } else {\n trigger.todo = Creator[\"eval\"](\"(function(userId, doc, fieldNames, modifier, options){\" + _todo_from_db + \"})\");\n }\n }\n }\n if (Meteor.isServer && trigger.on === \"client\") {\n _todo = trigger.todo;\n if (_todo && _.isFunction(_todo)) {\n return trigger._todo = _todo.toString();\n }\n }\n });\n if (Meteor.isClient) {\n _.forEach(object.fields, function(field, key) {\n var systemBaseFields;\n if (field.omit) {\n field.hidden = true;\n }\n if (field.required && field.readonly) {\n field.readonly = false;\n }\n systemBaseFields = Creator.getSystemBaseFields();\n if (systemBaseFields.indexOf(key) > -1) {\n return field.readonly = true;\n }\n });\n _.forEach(object.actions, function(action, key) {\n var _todo_from_code, _todo_from_db, _visible, error;\n _todo_from_code = action != null ? action._todo : void 0;\n _todo_from_db = action != null ? action.todo : void 0;\n if (_todo_from_code && _.isString(_todo_from_code)) {\n try {\n action.todo = Creator[\"eval\"](\"(\" + _todo_from_code + \")\");\n } catch (error1) {\n error = error1;\n console.error(\"todo_from_code\", _todo_from_code);\n }\n }\n if (_todo_from_db && _.isString(_todo_from_db)) {\n try {\n if (_todo_from_db.startsWith(\"function\")) {\n action.todo = Creator[\"eval\"](\"(\" + _todo_from_db + \")\");\n } else {\n if (_.isFunction(Creator.actionsByName[_todo_from_db])) {\n action.todo = _todo_from_db;\n } else {\n action.todo = Creator[\"eval\"](\"(function(){\" + _todo_from_db + \"})\");\n }\n }\n } catch (error1) {\n error = error1;\n console.error(\"todo_from_db\", _todo_from_db, error);\n }\n }\n _visible = action != null ? action._visible : void 0;\n if (_visible) {\n try {\n if (_.isString(_visible)) {\n _visible = _visible.trim();\n }\n if (Steedos.isExpression(_visible)) {\n return action.visible = function(object_name, record_id, record_permissions, record) {\n var globalData;\n globalData = Object.assign({}, Creator.USER_CONTEXT, {\n now: new Date()\n });\n return Steedos.parseSingleExpression(_visible, record, \"#\", globalData);\n };\n } else {\n return action.visible = Creator[\"eval\"](\"(\" + _visible + \")\");\n }\n } catch (error1) {\n error = error1;\n return console.error(\"action.visible to function error: \", error, _visible);\n }\n }\n });\n } else {\n _.forEach(object.actions, function(action, key) {\n var _todo, _visible;\n _todo = action != null ? action.todo : void 0;\n if (_todo && _.isFunction(_todo)) {\n action._todo = _todo.toString();\n }\n _visible = action != null ? action.visible : void 0;\n if (_visible && _.isFunction(_visible)) {\n return action._visible = _visible.toString();\n }\n });\n }\n _.forEach(object.fields, function(field, key) {\n var _options, _type, beforeOpenFunction, createFunction, defaultValue, error, filtersFunction, is_company_limited, max, min, options, optionsFunction, reference_to, regEx;\n field = convertField(object.name, key, field, spaceId);\n if (field.options && _.isString(field.options)) {\n try {\n _options = [];\n _.forEach(field.options.split(\"\\n\"), function(option) {\n var options;\n if (option.indexOf(\",\")) {\n options = option.split(\",\");\n return _.forEach(options, function(_option) {\n return _options.push(getOption(_option));\n });\n } else {\n return _options.push(getOption(option));\n }\n });\n field.options = _options;\n } catch (error1) {\n error = error1;\n console.error(\"Creator.convertFieldsOptions\", field.options, error);\n }\n } else if (field.options && _.isArray(field.options)) {\n try {\n _options = [];\n _.forEach(field.options, function(option) {\n if (_.isString(option)) {\n return _options.push(getOption(option));\n } else {\n return _options.push(option);\n }\n });\n field.options = _options;\n } catch (error1) {\n error = error1;\n console.error(\"Creator.convertFieldsOptions\", field.options, error);\n }\n } else if (field.options && !_.isFunction(field.options) && !_.isArray(field.options) && _.isObject(field.options)) {\n _options = [];\n _.each(field.options, function(v, k) {\n return _options.push({\n label: v,\n value: k\n });\n });\n field.options = _options;\n }\n if (Meteor.isServer) {\n options = field.options;\n if (options && _.isFunction(options)) {\n field._options = field.options.toString();\n }\n } else {\n options = field._options;\n if (options && _.isString(options)) {\n try {\n field.options = Creator[\"eval\"](\"(\" + options + \")\");\n } catch (error1) {\n error = error1;\n console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n }\n }\n }\n if (Meteor.isServer) {\n regEx = field.regEx;\n if (regEx) {\n field._regEx = field.regEx.toString();\n }\n } else {\n regEx = field._regEx;\n if (regEx) {\n try {\n field.regEx = Creator[\"eval\"](\"(\" + regEx + \")\");\n } catch (error1) {\n error = error1;\n console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n }\n }\n }\n if (Meteor.isServer) {\n min = field.min;\n if (_.isFunction(min)) {\n field._min = min.toString();\n }\n } else {\n min = field._min;\n if (_.isString(min)) {\n try {\n field.min = Creator[\"eval\"](\"(\" + min + \")\");\n } catch (error1) {\n error = error1;\n console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n }\n }\n }\n if (Meteor.isServer) {\n max = field.max;\n if (_.isFunction(max)) {\n field._max = max.toString();\n }\n } else {\n max = field._max;\n if (_.isString(max)) {\n try {\n field.max = Creator[\"eval\"](\"(\" + max + \")\");\n } catch (error1) {\n error = error1;\n console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n }\n }\n }\n if (Meteor.isServer) {\n if (field.autoform) {\n _type = field.autoform.type;\n if (_type && _.isFunction(_type) && _type !== Object && _type !== String && _type !== Number && _type !== Boolean && !_.isArray(_type)) {\n field.autoform._type = _type.toString();\n }\n }\n } else {\n if (field.autoform) {\n _type = field.autoform._type;\n if (_type && _.isString(_type)) {\n try {\n field.autoform.type = Creator[\"eval\"](\"(\" + _type + \")\");\n } catch (error1) {\n error = error1;\n console.error(\"convert field -> type error\", field, error);\n }\n }\n }\n }\n if (Meteor.isServer) {\n optionsFunction = field.optionsFunction;\n reference_to = field.reference_to;\n createFunction = field.createFunction;\n beforeOpenFunction = field.beforeOpenFunction;\n filtersFunction = field.filtersFunction;\n if (optionsFunction && _.isFunction(optionsFunction)) {\n field._optionsFunction = optionsFunction.toString();\n }\n if (reference_to && _.isFunction(reference_to)) {\n field._reference_to = reference_to.toString();\n }\n if (createFunction && _.isFunction(createFunction)) {\n field._createFunction = createFunction.toString();\n }\n if (beforeOpenFunction && _.isFunction(beforeOpenFunction)) {\n field._beforeOpenFunction = beforeOpenFunction.toString();\n }\n if (filtersFunction && _.isFunction(filtersFunction)) {\n field._filtersFunction = filtersFunction.toString();\n }\n } else {\n optionsFunction = field._optionsFunction || field.optionsFunction;\n reference_to = field._reference_to;\n createFunction = field._createFunction;\n beforeOpenFunction = field._beforeOpenFunction;\n filtersFunction = field._filtersFunction || field.filtersFunction;\n if (optionsFunction && _.isString(optionsFunction)) {\n field.optionsFunction = Creator[\"eval\"](\"(\" + optionsFunction + \")\");\n }\n if (reference_to && _.isString(reference_to)) {\n field.reference_to = Creator[\"eval\"](\"(\" + reference_to + \")\");\n }\n if (createFunction && _.isString(createFunction)) {\n field.createFunction = Creator[\"eval\"](\"(\" + createFunction + \")\");\n }\n if (beforeOpenFunction && _.isString(beforeOpenFunction)) {\n field.beforeOpenFunction = Creator[\"eval\"](\"(\" + beforeOpenFunction + \")\");\n }\n if (filtersFunction && _.isString(filtersFunction)) {\n field.filtersFunction = Creator[\"eval\"](\"(\" + filtersFunction + \")\");\n }\n }\n if (Meteor.isServer) {\n defaultValue = field.defaultValue;\n if (defaultValue && _.isFunction(defaultValue)) {\n field._defaultValue = field.defaultValue.toString();\n }\n } else {\n defaultValue = field._defaultValue;\n if (!defaultValue && _.isString(field.defaultValue) && field.defaultValue.startsWith(\"function\")) {\n defaultValue = field.defaultValue;\n }\n if (defaultValue && _.isString(defaultValue)) {\n try {\n field.defaultValue = Creator[\"eval\"](\"(\" + defaultValue + \")\");\n } catch (error1) {\n error = error1;\n console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n }\n }\n }\n if (Meteor.isServer) {\n is_company_limited = field.is_company_limited;\n if (is_company_limited && _.isFunction(is_company_limited)) {\n return field._is_company_limited = field.is_company_limited.toString();\n }\n } else {\n is_company_limited = field._is_company_limited;\n if (is_company_limited && _.isString(is_company_limited)) {\n try {\n return field.is_company_limited = Creator[\"eval\"](\"(\" + is_company_limited + \")\");\n } catch (error1) {\n error = error1;\n return console.error(\"convert error \" + object.name + \" -> \" + field.name, error);\n }\n }\n }\n });\n _.forEach(object.list_views, function(list_view, key) {\n\n /*\n \t\t\t视图过虑器需要支持function,后台转成字符串,前台eval成函数\n \t\t\t让过虑器支持两种function方式:\n \t\t\t1. 整个filters为function:\n \t\t\t如:\n \t\t\tfilters: ()->\n \t\t\t\treturn [[[\"object_name\",\"=\",\"project_issues\"],'or',[\"object_name\",\"=\",\"tasks\"]]]\n \t\t\t2. filters内的filter.value为function\n \t\t\t如:\n \t\t\tfilters: [[\"object_name\", \"=\", ()->\n \t\t\t\treturn \"project_issues\"\n \t\t\t]]\n \t\t\t或\n \t\t\tfilters: [{\n \t\t\t\t\"field\": \"object_name\"\n \t\t\t\t\"operation\": \"=\"\n \t\t\t\t\"value\": ()->\n \t\t\t\t\treturn \"project_issues\"\n \t\t\t}]\n */\n if (_.isFunction(list_view.filters)) {\n if (Meteor.isServer) {\n return list_view._filters = list_view.filters.toString();\n }\n } else if (_.isString(list_view._filters)) {\n if (Meteor.isClient) {\n return list_view.filters = Creator[\"eval\"](\"(\" + list_view._filters + \")\");\n }\n } else {\n return _.forEach(list_view.filters, function(filter, _index) {\n if (_.isArray(filter)) {\n if (Meteor.isServer) {\n if (filter.length === 3 && _.isFunction(filter[2])) {\n filter[2] = filter[2].toString();\n return filter[3] = \"FUNCTION\";\n } else if (filter.length === 3 && _.isDate(filter[2])) {\n return filter[3] = \"DATE\";\n }\n } else {\n if (filter.length === 4 && _.isString(filter[2]) && filter[3] === \"FUNCTION\") {\n filter[2] = Creator[\"eval\"](\"(\" + filter[2] + \")\");\n filter.pop();\n }\n if (filter.length === 4 && _.isString(filter[2]) && filter[3] === \"DATE\") {\n filter[2] = new Date(filter[2]);\n return filter.pop();\n }\n }\n } else if (_.isObject(filter)) {\n if (Meteor.isServer) {\n if (_.isFunction(filter != null ? filter.value : void 0)) {\n return filter._value = filter.value.toString();\n } else if (_.isDate(filter != null ? filter.value : void 0)) {\n return filter._is_date = true;\n }\n } else {\n if (_.isString(filter != null ? filter._value : void 0)) {\n return filter.value = Creator[\"eval\"](\"(\" + filter._value + \")\");\n } else if (filter._is_date === true) {\n return filter.value = new Date(filter.value);\n }\n }\n }\n });\n }\n });\n if (Meteor.isServer) {\n if (object.form && !_.isString(object.form)) {\n object.form = JSON.stringify(object.form, function(key, val) {\n if (_.isFunction(val)) {\n return val + '';\n } else {\n return val;\n }\n });\n }\n } else if (Meteor.isClient) {\n if (object.form) {\n object.form = JSON.parse(object.form, function(key, val) {\n if (_.isString(val) && val.startsWith('function')) {\n return Creator[\"eval\"](\"(\" + val + \")\");\n } else {\n return val;\n }\n });\n }\n }\n if (Meteor.isClient) {\n _.forEach(object.related_lists, function(relatedObjInfo) {\n if (_.isObject(relatedObjInfo)) {\n return _.forEach(relatedObjInfo, function(val, key) {\n var error;\n if (key === 'filters' && _.isString(val)) {\n try {\n return relatedObjInfo[key] = Creator[\"eval\"](\"(\" + val + \")\");\n } catch (error1) {\n error = error1;\n return console.error(\"filters_code\", val);\n }\n }\n });\n }\n });\n } else {\n _.forEach(object.related_lists, function(relatedObjInfo) {\n if (_.isObject(relatedObjInfo)) {\n return _.forEach(relatedObjInfo, function(val, key) {\n if (key === 'filters' && _.isFunction(val)) {\n return relatedObjInfo[key] = val.toString();\n }\n });\n }\n });\n }\n if (Meteor.isClient) {\n _.forEach(object.relatedList, function(relatedObjInfo) {\n if (_.isObject(relatedObjInfo)) {\n return _.forEach(relatedObjInfo, function(val, key) {\n var error;\n if (key === 'filters' && _.isString(val)) {\n try {\n return relatedObjInfo[key] = Creator[\"eval\"](\"(\" + val + \")\");\n } catch (error1) {\n error = error1;\n return console.error(\"filters_code\", val);\n }\n }\n });\n }\n });\n } else {\n _.forEach(object.relatedList, function(relatedObjInfo) {\n if (_.isObject(relatedObjInfo)) {\n return _.forEach(relatedObjInfo, function(val, key) {\n if (key === 'filters' && _.isFunction(val)) {\n return relatedObjInfo[key] = val.toString();\n }\n });\n }\n });\n }\n return object;\n};\n","Creator.Formular = {}\n\nCreator.Formular.PREFIX = \"_VALUES\"\n\nCreator.Formular._prependPrefixForFormula = (prefix,fieldVariable)->\n\treg = /(\\{[^{}]*\\})/g;\n\n\trev = fieldVariable.replace reg, (m, $1)->\n\t\treturn prefix + $1.replace(/\\{\\s*/,\"[\\\"\").replace(/\\s*\\}/,\"\\\"]\").replace(/\\s*\\.\\s*/g,\"\\\"][\\\"\");\n\n\treturn rev\n\nCreator.Formular.checkFormula = (formula_str)->\n\tif _.isString(formula_str) && formula_str.indexOf(\"{\") > -1 && formula_str.indexOf(\"}\") > -1\n\t\treturn true\n\treturn false\n\nCreator.Formular.run = (formula_str, _CONTEXT, options)->\n\tif formula_str && _.isString(formula_str)\n\n\t\tif !_.isBoolean(options?.extend)\n\t\t\textend = true\n\n\t\t_VALUES = {}\n\t\t_VALUES = _.extend(_VALUES, _CONTEXT)\n\t\tif extend\n\t\t\t_VALUES = _.extend(_VALUES, Creator.getUserContext(options?.userId, options?.spaceId))\n\t\tformula_str = Creator.Formular._prependPrefixForFormula(\"this\", formula_str)\n\n\t\ttry\n\t\t\tdata = Creator.evalInContext(formula_str, _VALUES) # 此处不能用window.eval ,会导致变量作用域异常\n\t\t\treturn data\n\t\tcatch e\n\t\t\tconsole.error(\"Creator.Formular.run: #{formula_str}\", e)\n\t\t\tif Meteor.isClient\n\t\t\t\ttoastr?.error(\"公式执行出错了,请检查公式配置是否正确!\")\n\t\t\tthrow new Meteor.Error 500, \"Creator.Formular.run: #{formula_str}#{e}\"\n\n\treturn formula_str\n","Creator.Formular = {};\n\nCreator.Formular.PREFIX = \"_VALUES\";\n\nCreator.Formular._prependPrefixForFormula = function(prefix, fieldVariable) {\n var reg, rev;\n reg = /(\\{[^{}]*\\})/g;\n rev = fieldVariable.replace(reg, function(m, $1) {\n return prefix + $1.replace(/\\{\\s*/, \"[\\\"\").replace(/\\s*\\}/, \"\\\"]\").replace(/\\s*\\.\\s*/g, \"\\\"][\\\"\");\n });\n return rev;\n};\n\nCreator.Formular.checkFormula = function(formula_str) {\n if (_.isString(formula_str) && formula_str.indexOf(\"{\") > -1 && formula_str.indexOf(\"}\") > -1) {\n return true;\n }\n return false;\n};\n\nCreator.Formular.run = function(formula_str, _CONTEXT, options) {\n var _VALUES, data, e, extend;\n if (formula_str && _.isString(formula_str)) {\n if (!_.isBoolean(options != null ? options.extend : void 0)) {\n extend = true;\n }\n _VALUES = {};\n _VALUES = _.extend(_VALUES, _CONTEXT);\n if (extend) {\n _VALUES = _.extend(_VALUES, Creator.getUserContext(options != null ? options.userId : void 0, options != null ? options.spaceId : void 0));\n }\n formula_str = Creator.Formular._prependPrefixForFormula(\"this\", formula_str);\n try {\n data = Creator.evalInContext(formula_str, _VALUES);\n return data;\n } catch (error) {\n e = error;\n console.error(\"Creator.Formular.run: \" + formula_str, e);\n if (Meteor.isClient) {\n if (typeof toastr !== \"undefined\" && toastr !== null) {\n toastr.error(\"公式执行出错了,请检查公式配置是否正确!\");\n }\n }\n throw new Meteor.Error(500, \"Creator.Formular.run: \" + formula_str + e);\n }\n }\n return formula_str;\n};\n","clone = require('clone');\nCreator.objectsByName = {} # 此对象只能在确保所有Object初始化完成后调用, 否则获取到的object不全\n\nCreator.formatObjectName = (object_name)->\n\tif object_name.startsWith('cfs.files.')\n\t\tobject_name = object_name.replace(new RegExp('\\\\.', 'g'), '_')\n\treturn object_name\n\nCreator.Object = (options)->\n\t_baseObject = Creator.baseObject\n\tif Meteor.isClient\n\t\t_baseObject = {actions: Creator.baseObject.actions , fields: {}, triggers: {}, permission_set: {}}\n\tself = this\n\tif (!options.name)\n\t\tconsole.error(options)\n\t\tthrow new Error('Creator.Object options must specify name');\n\n\tself._id = options._id || options.name\n\tself.space = options.space\n\tself.name = options.name\n\tself.label = options.label\n\tself.icon = options.icon\n\tself.description = options.description\n\tself.is_view = options.is_view\n\tself.form = options.form\n\tself.relatedList = options.relatedList\n\tself.related_lists = options.related_lists\n\tself.hasImportTemplates = options.hasImportTemplates\n\tself.version = options.version || 1.0\n\tif !_.isBoolean(options.is_enable) || options.is_enable == true\n\t\tself.is_enable = true\n\telse\n\t\tself.is_enable = false\n\tif Meteor.isClient\n\t\tif _.has(options, 'allow_customActions')\n\t\t\tself.allow_customActions = options.allow_customActions\n\t\tif _.has(options, 'exclude_actions')\n\t\t\tself.exclude_actions = options.exclude_actions\n\t\tif _.has(options, 'allow_relatedList')\n\t\t\tself.allow_relatedList = options.allow_relatedList\n\tself.enable_search = options.enable_search\n\tself.enable_files = options.enable_files\n\tself.enable_tasks = options.enable_tasks\n\tself.enable_notes = options.enable_notes\n\tself.enable_audit = options.enable_audit\n\tself.enable_events = options.enable_events\n\tif options.paging\n\t\tself.paging = options.paging\n\tself.hidden = options.hidden\n\tself.enable_api = (options.enable_api == undefined) or options.enable_api\n\tself.custom = options.custom\n\tself.enable_share = options.enable_share\n\tself.enable_instances = options.enable_instances\n\tself.enable_process = options.enable_process\n\tif Meteor.isClient\n\t\tif Creator.isCloudAdminSpace(Session.get(\"spaceId\"))\n\t\t\tself.enable_tree = false\n\t\telse\n\t\t\tself.enable_tree = options.enable_tree\n\t\t\tself.sidebar = _.clone(options.sidebar)\n\telse\n\t\tself.sidebar = _.clone(options.sidebar)\n\t\tself.enable_tree = options.enable_tree\n\tself.open_window = options.open_window\n\tself.filter_company = options.filter_company\n\tself.calendar = _.clone(options.calendar)\n\tself.enable_chatter = options.enable_chatter\n\tself.enable_trash = options.enable_trash\n\tself.enable_space_global = options.enable_space_global\n\tself.enable_approvals = options.enable_approvals\n\tself.enable_follow = options.enable_follow\n\tself.enable_workflow = options.enable_workflow\n\tself.enable_inline_edit = options.enable_inline_edit\n\tself.details = options.details\n\tself.masters = options.masters\n\tself.lookup_details = options.lookup_details\n\tif _.has(options, 'in_development')\n\t\tself.in_development = options.in_development\n\tself.idFieldName = '_id'\n\tif options.database_name\n\t\tself.database_name = options.database_name\n\tif (!options.fields)\n\t\tconsole.error(options)\n\t\tthrow new Error('Creator.Object options must specify fields');\n\n\tself.fields = clone(options.fields)\n\n\t_.each self.fields, (field, field_name)->\n\t\tif field.is_name\n\t\t\tself.NAME_FIELD_KEY = field_name\n\t\telse if field_name == 'name' && !self.NAME_FIELD_KEY\n\t\t\tself.NAME_FIELD_KEY = field_name\n\t\tif field.primary\n\t\t\tself.idFieldName = field_name\n\t\tif Meteor.isClient\n\t\t\tif Creator.isCloudAdminSpace(Session.get(\"spaceId\"))\n\t\t\t\tif field_name == 'space'\n\t\t\t\t\tfield.filterable = true\n\t\t\t\t\tfield.hidden = false\n\n\tif !options.database_name || options.database_name == 'meteor-mongo'\n\t\t_.each _baseObject.fields, (field, field_name)->\n\t\t\tif !self.fields[field_name]\n\t\t\t\tself.fields[field_name] = {}\n\t\t\tself.fields[field_name] = _.extend(_.clone(field), self.fields[field_name])\n\n\t_.each self.fields, (field, field_name)->\n\t\tif field.type == 'autonumber'\n\t\t\tfield.readonly = true\n\t\telse if field.type == 'formula'\n\t\t\tfield.readonly = true\n\t\telse if field.type == 'summary'\n\t\t\tfield.readonly = true\n\n\tself.list_views = {}\n\tdefaultView = Creator.getObjectDefaultView(self.name)\n\t_.each options.list_views, (item, item_name)->\n\t\toitem = Creator.convertListView(defaultView, item, item_name)\n\t\tself.list_views[item_name] = oitem\n\n\tself.triggers = _.clone(_baseObject.triggers)\n\t_.each options.triggers, (item, item_name)->\n\t\tif !self.triggers[item_name]\n\t\t\tself.triggers[item_name] = {}\n\t\tself.triggers[item_name].name = item_name\n\t\tself.triggers[item_name] = _.extend(_.clone(self.triggers[item_name]), item)\n\n\tself.actions = _.clone(_baseObject.actions)\n\t_.each options.actions, (item, item_name)->\n\t\tif !self.actions[item_name]\n\t\t\tself.actions[item_name] = {}\n\t\tcopyItem = _.clone(self.actions[item_name])\n\t\tdelete self.actions[item_name] #先删除相关属性再重建才能保证后续重复定义的属性顺序生效\n\t\tself.actions[item_name] = _.extend(copyItem, item)\n\t\tself.actions[item_name].object_name = self.name\n\n\t_.each self.actions, (item, item_name)->\n\t\titem.name = item_name\n\n\tself.related_objects = Creator.getObjectRelateds(self.name)\n\n\t# 让所有object默认有所有list_views/actions/related_objects/readable_fields/editable_fields完整权限,该权限可能被数据库中设置的admin/user权限覆盖\n\tself.permission_set = _.clone(_baseObject.permission_set)\n\t# defaultListViews = _.keys(self.list_views)\n\t# defaultActions = _.keys(self.actions)\n\t# defaultRelatedObjects = _.pluck(self.related_objects,\"object_name\")\n\t# defaultReadableFields = []\n\t# defaultEditableFields = []\n\t# _.each self.fields, (field, field_name)->\n\t# \tif !(field.hidden) #231 omit字段支持在非编辑页面查看, 因此删除了此处对omit的判断\n\t# \t\tdefaultReadableFields.push field_name\n\t# \t\tif !field.readonly\n\t# \t\t\tdefaultEditableFields.push field_name\n\n\t# _.each self.permission_set, (item, item_name)->\n\t# \tif item_name == \"none\"\n\t# \t\treturn\n\t# \tif self.list_views\n\t# \t\tself.permission_set[item_name].list_views = defaultListViews\n\t# \tif self.actions\n\t# \t\tself.permission_set[item_name].actions = defaultActions\n\t# \tif self.related_objects\n\t# \t\tself.permission_set[item_name].related_objects = defaultRelatedObjects\n\t# \tif self.fields\n\t# \t\tself.permission_set[item_name].readable_fields = defaultReadableFields\n\t# \t\tself.permission_set[item_name].editable_fields = defaultEditableFields\n\tunless options.permission_set\n\t\toptions.permission_set = {}\n\tif !(options.permission_set?.admin)\n\t\toptions.permission_set.admin = _.clone(self.permission_set[\"admin\"])\n\tif !(options.permission_set?.user)\n\t\toptions.permission_set.user = _.clone(self.permission_set[\"user\"])\n\t_.each options.permission_set, (item, item_name)->\n\t\tif !self.permission_set[item_name]\n\t\t\tself.permission_set[item_name] = {}\n\t\tself.permission_set[item_name] = _.extend(_.clone(self.permission_set[item_name]), item)\n\n\t# 前端根据permissions改写field相关属性,后端只要走默认属性就行,不需要改写\n\tif Meteor.isClient\n\t\tpermissions = options.permissions\n\t\tdisabled_list_views = permissions?.disabled_list_views\n\t\tif disabled_list_views?.length\n\t\t\tdefaultListViewId = options.list_views?.all?._id\n\t\t\tif defaultListViewId\n\t\t\t\t# 把视图权限配置中默认的all视图id转换成all关键字\n\t\t\t\tpermissions.disabled_list_views = _.map disabled_list_views, (list_view_item) ->\n\t\t\t\t\treturn if defaultListViewId == list_view_item then \"all\" else list_view_item\n\t\tself.permissions = new ReactiveVar(permissions)\n#\t\t_.each self.fields, (field, field_name)->\n#\t\t\tif field\n#\t\t\t\tif _.indexOf(permissions?.unreadable_fields, field_name) < 0\n#\t\t\t\t\tif field.hidden\n#\t\t\t\t\t\treturn\n#\t\t\t\t\tif _.indexOf(permissions?.uneditable_fields, field_name) > -1\n#\t\t\t\t\t\tfield.readonly = true\n#\t\t\t\t\t\tfield.disabled = true\n#\t\t\t\t\t\t# 当只读时,如果不去掉必填字段,autoform是会报错的\n#\t\t\t\t\t\tfield.required = false\n#\t\t\t\telse\n#\t\t\t\t\tfield.hidden = true\n\telse\n\t\tself.permissions = null\n\n\t_db = Creator.createCollection(options)\n\n\tCreator.Collections[_db._name] = _db\n\n\tself.db = _db\n\n\tself._collection_name = _db._name\n\n\tschema = Creator.getObjectSchema(self)\n\tself.schema = new SimpleSchema(schema)\n\tif self.name != \"users\" and self.name != \"cfs.files.filerecord\" && !self.is_view && !_.contains([\"flows\", \"forms\", \"instances\", \"organizations\", \"action_field_updates\", \"object_listviews\"], self.name)\n\t\tif Meteor.isClient\n\t\t\t_db.attachSchema(self.schema, {replace: true})\n\t\telse\n\t\t\t_db.attachSchema(self.schema, {replace: true})\n\tif self.name == \"users\"\n\t\t_db._simpleSchema = self.schema\n\n\tif _.contains([\"flows\", \"forms\", \"instances\", \"organizations\"], self.name)\n\t\tif Meteor.isClient\n\t\t\t_db.attachSchema(self.schema, {replace: true})\n\n\tCreator.objectsByName[self._collection_name] = self\n\n\treturn self\n\n# Creator.Object.prototype.i18n = ()->\n# \t# set object label\n# \tself = this\n\n# \tkey = self.name\n# \tif t(key) == key\n# \t\tif !self.label\n# \t\t\tself.label = self.name\n# \telse\n# \t\tself.label = t(key)\n\n# \t# set field labels\n# \t_.each self.fields, (field, field_name)->\n# \t\tfkey = self.name + \"_\" + field_name\n# \t\tif t(fkey) == fkey\n# \t\t\tif !field.label\n# \t\t\t\tfield.label = field_name\n# \t\telse\n# \t\t\tfield.label = t(fkey)\n# \t\tself.schema?._schema?[field_name]?.label = field.label\n\n\n# \t# set listview labels\n# \t_.each self.list_views, (item, item_name)->\n# \t\ti18n_key = self.name + \"_listview_\" + item_name\n# \t\tif t(i18n_key) == i18n_key\n# \t\t\tif !item.label\n# \t\t\t\titem.label = item_name\n# \t\telse\n# \t\t\titem.label = t(i18n_key)\n\n\nCreator.getObjectODataRouterPrefix = (object)->\n\treturn \"/api/odata/v4\"\n\t# if object\n\t# \tif !object.database_name || object.database_name == 'meteor-mongo'\n\t# \t\treturn \"/api/odata/v4\"\n\t# \telse\n\t# \t\treturn \"/api/odata/#{object.database_name}\"\n\n# if Meteor.isClient\n\n# \tMeteor.startup ->\n# \t\tTracker.autorun ->\n# \t\t\tif Session.get(\"steedos-locale\") && Creator.bootstrapLoaded?.get()\n# \t\t\t\t_.each Creator.objectsByName, (object, object_name)->\n# \t\t\t\t\tobject.i18n()\n\nMeteor.startup ->\n\tif !Creator.bootstrapLoaded && Creator.Objects\n\t\t_.each Creator.Objects, (object)->\n\t\t\tnew Creator.Object(object)\n\n","var clone;\n\nclone = require('clone');\n\nCreator.objectsByName = {};\n\nCreator.formatObjectName = function(object_name) {\n if (object_name.startsWith('cfs.files.')) {\n object_name = object_name.replace(new RegExp('\\\\.', 'g'), '_');\n }\n return object_name;\n};\n\nCreator.Object = function(options) {\n var _baseObject, _db, defaultListViewId, defaultView, disabled_list_views, permissions, ref, ref1, ref2, ref3, schema, self;\n _baseObject = Creator.baseObject;\n if (Meteor.isClient) {\n _baseObject = {\n actions: Creator.baseObject.actions,\n fields: {},\n triggers: {},\n permission_set: {}\n };\n }\n self = this;\n if (!options.name) {\n console.error(options);\n throw new Error('Creator.Object options must specify name');\n }\n self._id = options._id || options.name;\n self.space = options.space;\n self.name = options.name;\n self.label = options.label;\n self.icon = options.icon;\n self.description = options.description;\n self.is_view = options.is_view;\n self.form = options.form;\n self.relatedList = options.relatedList;\n self.related_lists = options.related_lists;\n self.hasImportTemplates = options.hasImportTemplates;\n self.version = options.version || 1.0;\n if (!_.isBoolean(options.is_enable) || options.is_enable === true) {\n self.is_enable = true;\n } else {\n self.is_enable = false;\n }\n if (Meteor.isClient) {\n if (_.has(options, 'allow_customActions')) {\n self.allow_customActions = options.allow_customActions;\n }\n if (_.has(options, 'exclude_actions')) {\n self.exclude_actions = options.exclude_actions;\n }\n if (_.has(options, 'allow_relatedList')) {\n self.allow_relatedList = options.allow_relatedList;\n }\n }\n self.enable_search = options.enable_search;\n self.enable_files = options.enable_files;\n self.enable_tasks = options.enable_tasks;\n self.enable_notes = options.enable_notes;\n self.enable_audit = options.enable_audit;\n self.enable_events = options.enable_events;\n if (options.paging) {\n self.paging = options.paging;\n }\n self.hidden = options.hidden;\n self.enable_api = (options.enable_api === void 0) || options.enable_api;\n self.custom = options.custom;\n self.enable_share = options.enable_share;\n self.enable_instances = options.enable_instances;\n self.enable_process = options.enable_process;\n if (Meteor.isClient) {\n if (Creator.isCloudAdminSpace(Session.get(\"spaceId\"))) {\n self.enable_tree = false;\n } else {\n self.enable_tree = options.enable_tree;\n self.sidebar = _.clone(options.sidebar);\n }\n } else {\n self.sidebar = _.clone(options.sidebar);\n self.enable_tree = options.enable_tree;\n }\n self.open_window = options.open_window;\n self.filter_company = options.filter_company;\n self.calendar = _.clone(options.calendar);\n self.enable_chatter = options.enable_chatter;\n self.enable_trash = options.enable_trash;\n self.enable_space_global = options.enable_space_global;\n self.enable_approvals = options.enable_approvals;\n self.enable_follow = options.enable_follow;\n self.enable_workflow = options.enable_workflow;\n self.enable_inline_edit = options.enable_inline_edit;\n self.details = options.details;\n self.masters = options.masters;\n self.lookup_details = options.lookup_details;\n if (_.has(options, 'in_development')) {\n self.in_development = options.in_development;\n }\n self.idFieldName = '_id';\n if (options.database_name) {\n self.database_name = options.database_name;\n }\n if (!options.fields) {\n console.error(options);\n throw new Error('Creator.Object options must specify fields');\n }\n self.fields = clone(options.fields);\n _.each(self.fields, function(field, field_name) {\n if (field.is_name) {\n self.NAME_FIELD_KEY = field_name;\n } else if (field_name === 'name' && !self.NAME_FIELD_KEY) {\n self.NAME_FIELD_KEY = field_name;\n }\n if (field.primary) {\n self.idFieldName = field_name;\n }\n if (Meteor.isClient) {\n if (Creator.isCloudAdminSpace(Session.get(\"spaceId\"))) {\n if (field_name === 'space') {\n field.filterable = true;\n return field.hidden = false;\n }\n }\n }\n });\n if (!options.database_name || options.database_name === 'meteor-mongo') {\n _.each(_baseObject.fields, function(field, field_name) {\n if (!self.fields[field_name]) {\n self.fields[field_name] = {};\n }\n return self.fields[field_name] = _.extend(_.clone(field), self.fields[field_name]);\n });\n }\n _.each(self.fields, function(field, field_name) {\n if (field.type === 'autonumber') {\n return field.readonly = true;\n } else if (field.type === 'formula') {\n return field.readonly = true;\n } else if (field.type === 'summary') {\n return field.readonly = true;\n }\n });\n self.list_views = {};\n defaultView = Creator.getObjectDefaultView(self.name);\n _.each(options.list_views, function(item, item_name) {\n var oitem;\n oitem = Creator.convertListView(defaultView, item, item_name);\n return self.list_views[item_name] = oitem;\n });\n self.triggers = _.clone(_baseObject.triggers);\n _.each(options.triggers, function(item, item_name) {\n if (!self.triggers[item_name]) {\n self.triggers[item_name] = {};\n }\n self.triggers[item_name].name = item_name;\n return self.triggers[item_name] = _.extend(_.clone(self.triggers[item_name]), item);\n });\n self.actions = _.clone(_baseObject.actions);\n _.each(options.actions, function(item, item_name) {\n var copyItem;\n if (!self.actions[item_name]) {\n self.actions[item_name] = {};\n }\n copyItem = _.clone(self.actions[item_name]);\n delete self.actions[item_name];\n self.actions[item_name] = _.extend(copyItem, item);\n return self.actions[item_name].object_name = self.name;\n });\n _.each(self.actions, function(item, item_name) {\n return item.name = item_name;\n });\n self.related_objects = Creator.getObjectRelateds(self.name);\n self.permission_set = _.clone(_baseObject.permission_set);\n if (!options.permission_set) {\n options.permission_set = {};\n }\n if (!((ref = options.permission_set) != null ? ref.admin : void 0)) {\n options.permission_set.admin = _.clone(self.permission_set[\"admin\"]);\n }\n if (!((ref1 = options.permission_set) != null ? ref1.user : void 0)) {\n options.permission_set.user = _.clone(self.permission_set[\"user\"]);\n }\n _.each(options.permission_set, function(item, item_name) {\n if (!self.permission_set[item_name]) {\n self.permission_set[item_name] = {};\n }\n return self.permission_set[item_name] = _.extend(_.clone(self.permission_set[item_name]), item);\n });\n if (Meteor.isClient) {\n permissions = options.permissions;\n disabled_list_views = permissions != null ? permissions.disabled_list_views : void 0;\n if (disabled_list_views != null ? disabled_list_views.length : void 0) {\n defaultListViewId = (ref2 = options.list_views) != null ? (ref3 = ref2.all) != null ? ref3._id : void 0 : void 0;\n if (defaultListViewId) {\n permissions.disabled_list_views = _.map(disabled_list_views, function(list_view_item) {\n if (defaultListViewId === list_view_item) {\n return \"all\";\n } else {\n return list_view_item;\n }\n });\n }\n }\n self.permissions = new ReactiveVar(permissions);\n } else {\n self.permissions = null;\n }\n _db = Creator.createCollection(options);\n Creator.Collections[_db._name] = _db;\n self.db = _db;\n self._collection_name = _db._name;\n schema = Creator.getObjectSchema(self);\n self.schema = new SimpleSchema(schema);\n if (self.name !== \"users\" && self.name !== \"cfs.files.filerecord\" && !self.is_view && !_.contains([\"flows\", \"forms\", \"instances\", \"organizations\", \"action_field_updates\", \"object_listviews\"], self.name)) {\n if (Meteor.isClient) {\n _db.attachSchema(self.schema, {\n replace: true\n });\n } else {\n _db.attachSchema(self.schema, {\n replace: true\n });\n }\n }\n if (self.name === \"users\") {\n _db._simpleSchema = self.schema;\n }\n if (_.contains([\"flows\", \"forms\", \"instances\", \"organizations\"], self.name)) {\n if (Meteor.isClient) {\n _db.attachSchema(self.schema, {\n replace: true\n });\n }\n }\n Creator.objectsByName[self._collection_name] = self;\n return self;\n};\n\nCreator.getObjectODataRouterPrefix = function(object) {\n return \"/api/odata/v4\";\n};\n\nMeteor.startup(function() {\n if (!Creator.bootstrapLoaded && Creator.Objects) {\n return _.each(Creator.Objects, function(object) {\n return new Creator.Object(object);\n });\n }\n});\n","Creator.getSelectOptions = (fieldSchema) ->\n\toptions = fieldSchema.options\n\tunless options\n\t\treturn\n\tdata_type = fieldSchema.data_type\n\tif !_.isFunction(options) and data_type and data_type != 'text'\n\t\t# 零代码界面配置options选项值只支持字符串,所以当data_type为数值或boolean时,只能强行把选项值先转换为对应的类型\n\t\toptions.forEach (optionItem) ->\n\t\t\tif typeof optionItem.value != 'string'\n\t\t\t\treturn\n\t\t\tif [\n\t\t\t\t'number'\n\t\t\t\t'currency'\n\t\t\t\t'percent'\n\t\t\t].indexOf(data_type) > -1\n\t\t\t\toptionItem.value = Number(optionItem.value)\n\t\t\telse if data_type == 'boolean'\n\t\t\t\t# 只有为true才为真\n\t\t\t\toptionItem.value = optionItem.value == 'true'\n\treturn options\n\nCreator.getObjectSchema = (obj) ->\n\tunless obj\n\t\treturn\n\tschema = {}\n\n\tfieldsArr = []\n\n\t_.each obj.fields , (field, field_name)->\n\t\tif !_.has(field, \"name\")\n\t\t\tfield.name = field_name\n\t\tfieldsArr.push field\n\n\t_.each _.sortBy(fieldsArr, \"sort_no\"), (field)->\n\n\t\tfield_name = field.name\n\n\t\tfs = {}\n\t\tif field.regEx\n\t\t\tfs.regEx = field.regEx\n\t\tfs.autoform = {}\n\t\tfs.autoform.multiple = field.multiple\n\t\tfs.autoform.reference_to = field.reference_to\n\n\t\tautoform_type = field.autoform?.type\n\n\t\tif field.type == \"text\" or field.type == \"phone\"\n\t\t\tfs.type = String\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tfs.autoform.type = \"tags\"\n\t\telse if field.type == \"[text]\" or field.type == \"[phone]\"\n\t\t\tfs.type = [String]\n\t\t\tfs.autoform.type = \"tags\"\n\t\telse if field.type == 'code'\n\t\t\tfs.type = String\n\t\t\tfs.autoform.type = \"widearea\"\n\t\t\tfs.autoform.rows = field.rows || 12\n\t\t\tif field.language\n\t\t\t\tfs.autoform.language = field.language\n\t\telse if field.type == \"textarea\"\n\t\t\tfs.type = String\n\t\t\tfs.autoform.type = \"widearea\"\n\t\t\tfs.autoform.rows = field.rows || 2\n\t\telse if field.type == \"password\"\n\t\t\tfs.type = String\n\t\t\tfs.autoform.type = \"password\"\n\t\telse if field.type == \"date\"\n\t\t\tfs.type = Date\n\t\t\tif Meteor.isClient\n\t\t\t\tif Steedos.isMobile() || Steedos.isPad()\n\t\t\t\t\tif Steedos.isiOS()\n\t\t\t\t\t\t# Fix ios 14, 手机客户端待审核文件日期控件显示故障 #991,ios统一用PC端一样的js控件\n\t\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\t\t\ttimezoneId: \"utc\"\n\t\t\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\t\t\ttype: \"date\"\n\t\t\t\t\t\t\t\tdisplayFormat: \"yyyy-MM-dd\"\n\t\t\t\t\t\t\t\tpickerType: \"rollers\"\n\t\t\t\t\telse\n\t\t\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\t\ttype: \"steedos-date-mobile\"\n\t\t\t\t\t\t\tdateMobileOptions:\n\t\t\t\t\t\t\t\ttype: \"date\"\n\t\t\t\telse\n\t\t\t\t\tfs.autoform.outFormat = 'yyyy-MM-dd';\n\t\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\t\ttimezoneId: \"utc\"\n\t\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\t\ttype: \"date\"\n\t\t\t\t\t\t\tdisplayFormat: \"yyyy-MM-dd\"\n\t\telse if field.type == \"time\"\n\t\t\tfs.type = Date\n\t\t\tif Meteor.isClient\n\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\ttimezoneId: \"utc\"\n\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\ttype: \"time\"\n\t\t\t\t\t\tdisplayFormat: \"HH:mm\"\n\t\telse if field.type == \"datetime\"\n\t\t\tfs.type = Date\n\t\t\tif Meteor.isClient\n\t\t\t\tif Steedos.isMobile() || Steedos.isPad()\n\t\t\t\t\tif Steedos.isiOS()\n\t\t\t\t\t\t# Fix ios 14, 手机客户端待审核文件日期控件显示故障 #991,ios统一用PC端一样的js控件\n\t\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\t\t\ttype: \"datetime\"\n\t\t\t\t\t\t\t\tdisplayFormat: \"yyyy-MM-dd HH:mm\"\n\t\t\t\t\t\t\t\tpickerType: \"rollers\"\n\t\t\t\t\telse\n\t\t\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\t\ttype: \"steedos-date-mobile\"\n\t\t\t\t\t\t\tdateMobileOptions:\n\t\t\t\t\t\t\t\ttype: \"datetime\"\n\t\t\t\telse\n\t\t\t\t\t# 这里用afFieldInput而不直接用autoform的原因是当字段被hidden的时候去执行dxDateBoxOptions参数会报错\n\t\t\t\t\tfs.autoform.afFieldInput =\n\t\t\t\t\t\ttype: \"dx-date-box\"\n\t\t\t\t\t\tdxDateBoxOptions:\n\t\t\t\t\t\t\ttype: \"datetime\"\n\t\t\t\t\t\t\tdisplayFormat: \"yyyy-MM-dd HH:mm\"\n\t\telse if field.type == \"[Object]\"\n\t\t\tfs.type = [Object]\n\t\telse if field.type == \"html\"\n\t\t\tfs.type = String\n\t\t\tif Meteor.isClient\n\t\t\t\tfs.autoform.type = 'steedosHtml';\n\t\t\t# if Meteor.isClient\n\t\t\t# \tlocale = Steedos.locale()\n\t\t\t# \tif locale == \"zh-cn\" || locale == \"zh-CN\"\n\t\t\t# \t\tlocale = \"zh-CN\"\n\t\t\t# \telse\n\t\t\t# \t\tlocale = \"en-US\"\n\t\t\t# \tfs.autoform.afFieldInput =\n\t\t\t# \t\ttype: \"summernote\"\n\t\t\t# \t\tclass: 'summernote-editor'\n\t\t\t# \t\tsettings:\n\t\t\t# \t\t\theight: 200\n\t\t\t# \t\t\tdialogsInBody: true\n\t\t\t# \t\t\ttoolbar: [\n\t\t\t# \t\t\t\t['font1', ['style']],\n\t\t\t# \t\t\t\t['font2', ['bold', 'underline', 'italic', 'clear']],\n\t\t\t# \t\t\t\t['font3', ['fontname']],\n\t\t\t# \t\t\t\t['color', ['color']],\n\t\t\t# \t\t\t\t['para', ['ul', 'ol', 'paragraph']],\n\t\t\t# \t\t\t\t['table', ['table']],\n\t\t\t# \t\t\t\t['insert', ['link', 'picture']],\n\t\t\t# \t\t\t\t['view', ['codeview']]\n\t\t\t# \t\t\t]\n\t\t\t# \t\t\tfontNames: ['Arial', 'Comic Sans MS', 'Courier New', 'Helvetica', 'Impact', '宋体','黑体','微软雅黑','仿宋','楷体','隶书','幼圆']\n\t\t\t# \t\t\tlang: locale\n\n\t\telse if (field.type == \"lookup\" or field.type == \"master_detail\")\n\t\t\tfs.type = String\n\t\t\tfs.autoform.showIcon = field.showIcon\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\n\t\t\tif !field.hidden\n\n\t\t\t\tfs.autoform.filters = field.filters\n\n\t\t\t\tfs.autoform.dependOn = field.depend_on\n\n\t\t\t\tif field.beforeOpenFunction\n\t\t\t\t\tfs.beforeOpenFunction = field.beforeOpenFunction\n\n\t\t\t\tfs.filtersFunction = if field.filtersFunction then field.filtersFunction else Creator.evaluateFilters\n\n\t\t\t\tif field.optionsFunction\n\t\t\t\t\tfs.optionsFunction = field.optionsFunction\n\n\t\t\t\tif field.reference_to\n\n\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\tif field.createFunction && _.isFunction(field.createFunction)\n\t\t\t\t\t\t\tfs.createFunction = field.createFunction\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tif _.isString(field.reference_to)\n\t\t\t\t\t\t\t\t_ref_obj = Creator.Objects[field.reference_to]\n\t\t\t\t\t\t\t\tif _ref_obj?.permissions?.allowCreate\n\t\t\t\t\t\t\t\t\tfs.autoform.create = true\n\t\t\t\t\t\t\t\t\tfs.createFunction = (lookup_field)->\n\t\t\t\t\t\t\t\t\t\tModal.show(\"CreatorObjectModal\", {\n\t\t\t\t\t\t\t\t\t\t\tcollection: \"Creator.Collections.#{Creator.getCollection(field.reference_to)._name}\",\n\t\t\t\t\t\t\t\t\t\t\tformId: \"new#{field.reference_to.replace('.','_')}\",\n\t\t\t\t\t\t\t\t\t\t\tobject_name: \"#{field.reference_to}\",\n\t\t\t\t\t\t\t\t\t\t\toperation: \"insert\",\n\t\t\t\t\t\t\t\t\t\t\tonSuccess: (operation, result)->\n\t\t\t\t\t\t\t\t\t\t\t\tobject = Creator.getObject(result.object_name)\n\t\t\t\t\t\t\t\t\t\t\t\tif result.object_name == \"objects\"\n\t\t\t\t\t\t\t\t\t\t\t\t\tlookup_field.addItems([{label: result.value.label, value: result.value.name, icon: result.value.icon}], result.value.name)\n\t\t\t\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\t\t\t\tlookup_field.addItems([{label: result.value[object.NAME_FIELD_KEY] || result.value.label || result.value.name, value: result._id}], result._id)\n\t\t\t\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\tfs.autoform.create = false\n\n\t\t\t\t\tif _.isBoolean(field.create)\n\t\t\t\t\t\tfs.autoform.create = field.create\n\n\t\t\t\t\tif field.reference_sort\n\t\t\t\t\t\tfs.autoform.optionsSort = field.reference_sort\n\n\t\t\t\t\tif field.reference_limit\n\t\t\t\t\t\tfs.autoform.optionsLimit = field.reference_limit\n\t\t\t\t\tif field.reference_to_field\n\t\t\t\t\t\tfs.autoform.referenceToField = field.reference_to_field\n\n\t\t\t\t\tif field.reference_to == \"users\"\n\t\t\t\t\t\tfs.autoform.type = \"selectuser\"\n\t\t\t\t\t\tif !field.hidden && !field.omit\n\t\t\t\t\t\t\t# is_company_limited表示过滤数据时是否只显示本分部下的数据\n\t\t\t\t\t\t\t# is_company_limited可以被改写覆盖成true/false或其他function\n\t\t\t\t\t\t\tif field.is_company_limited == undefined\n\t\t\t\t\t\t\t\t# 未定义is_company_limited属性时默认处理逻辑:\n\t\t\t\t\t\t\t\t# 对当前对象有viewAllRecords权限则不限制所属分部列表查看权限,否则只显示当前所属分部\n\t\t\t\t\t\t\t\t# 注意不是reference_to对象的viewAllRecords权限,而是当前对象的\n\t\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\t\tpermissions = obj.permissions\n\t\t\t\t\t\t\t\t\tisUnLimited = permissions?.viewAllRecords\n\t\t\t\t\t\t\t\t\tif _.include([\"organizations\", \"users\", \"space_users\"], obj.name)\n\t\t\t\t\t\t\t\t\t\t# 如果字段所属对象是用户或组织,则是否限制显示所属分部部门与modifyAllRecords权限关联\n\t\t\t\t\t\t\t\t\t\tisUnLimited = permissions?.modifyAllRecords\n\t\t\t\t\t\t\t\t\tif isUnLimited\n\t\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = false\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = true\n\t\t\t\t\t\t\telse if _.isFunction field.is_company_limited\n\t\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\t\t# 传入当前对象的权限,在函数中根据权限计算是否要限制只查看本分部\n\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited(obj.permissions)\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t# 服务端用不到is_company_limited\n\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = true\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited\n\t\t\t\t\telse if field.reference_to == \"organizations\"\n\t\t\t\t\t\tfs.autoform.type = \"selectorg\"\n\t\t\t\t\t\tif !field.hidden && !field.omit\n\t\t\t\t\t\t\t# is_company_limited表示过滤数据时是否只显示本分部下的数据\n\t\t\t\t\t\t\t# is_company_limited可以被改写覆盖成true/false或其他function\n\t\t\t\t\t\t\tif field.is_company_limited == undefined\n\t\t\t\t\t\t\t\t# 未定义is_company_limited属性时默认处理逻辑:\n\t\t\t\t\t\t\t\t# 对当前对象有viewAllRecords权限则不限制所属分部列表查看权限,否则只显示当前所属分部\n\t\t\t\t\t\t\t\t# 注意不是reference_to对象的viewAllRecords权限,而是当前对象的\n\t\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\t\tpermissions = obj.permissions\n\t\t\t\t\t\t\t\t\tisUnLimited = permissions?.viewAllRecords\n\t\t\t\t\t\t\t\t\tif _.include([\"organizations\", \"users\", \"space_users\"], obj.name)\n\t\t\t\t\t\t\t\t\t\t# 如果字段所属对象是用户或组织,则是否限制显示所属分部部门与modifyAllRecords权限关联\n\t\t\t\t\t\t\t\t\t\tisUnLimited = permissions?.modifyAllRecords\n\t\t\t\t\t\t\t\t\tif isUnLimited\n\t\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = false\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = true\n\t\t\t\t\t\t\telse if _.isFunction field.is_company_limited\n\t\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\t\t# 传入当前对象的权限,在函数中根据权限计算是否要限制只查看本分部\n\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited(obj.permissions)\n\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t# 服务端用不到is_company_limited\n\t\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = true\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tfs.autoform.is_company_limited = field.is_company_limited\n\t\t\t\t\telse\n\t\t\t\t\t\tif typeof(field.reference_to) == \"function\"\n\t\t\t\t\t\t\t_reference_to = field.reference_to()\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t_reference_to = field.reference_to\n\n\t\t\t\t\t\tif _.isArray(_reference_to)\n\t\t\t\t\t\t\tfs.type = Object\n\t\t\t\t\t\t\tfs.blackbox = true\n\t\t\t\t\t\t\tfs.autoform.objectSwitche = true\n\n\t\t\t\t\t\t\tschema[field_name + \".o\"] = {\n\t\t\t\t\t\t\t\ttype: String\n\t\t\t\t\t\t\t\tautoform: {omit: true}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tschema[field_name + \".ids\"] = {\n\t\t\t\t\t\t\t\ttype: [String]\n\t\t\t\t\t\t\t\tautoform: {omit: true}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t_reference_to = [_reference_to]\n\n\t\t\t\t\t\t_object = Creator.Objects[_reference_to[0]]\n\t\t\t\t\t\tif _object and _object.enable_tree\n\t\t\t\t\t\t\tfs.autoform.type = \"selectTree\"\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\tfs.autoform.type = \"steedosLookups\"\n\t\t\t\t\t\t\tfs.autoform.optionsMethod = field.optionsMethod || \"creator.object_options\"\n\n\t\t\t\t\t\t\tif Meteor.isClient\n\t\t\t\t\t\t\t\tfs.autoform.optionsMethodParams = ()->\n\t\t\t\t\t\t\t\t\treturn {space: Session.get(\"spaceId\")}\n\t\t\t\t\t\t\t\tfs.autoform.references = []\n\t\t\t\t\t\t\t\t_reference_to.forEach (_reference)->\n\t\t\t\t\t\t\t\t\t_object = Creator.Objects[_reference]\n\t\t\t\t\t\t\t\t\tif _object\n\t\t\t\t\t\t\t\t\t\tfs.autoform.references.push {\n\t\t\t\t\t\t\t\t\t\t\tobject: _reference\n\t\t\t\t\t\t\t\t\t\t\tlabel: _object?.label\n\t\t\t\t\t\t\t\t\t\t\ticon: _object?.icon\n\t\t\t\t\t\t\t\t\t\t\tlink: ()->\n\t\t\t\t\t\t\t\t\t\t\t\treturn \"/app/#{Session.get('app_id')}/#{_reference}/view/\"\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tfs.autoform.references.push {\n\t\t\t\t\t\t\t\t\t\t\tobject: _reference\n\t\t\t\t\t\t\t\t\t\t\tlink: ()->\n\t\t\t\t\t\t\t\t\t\t\t\treturn \"/app/#{Session.get('app_id')}/#{_reference}/view/\"\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\telse\n\t\t\t\t\tfs.autoform.type = \"steedosLookups\"\n\t\t\t\t\tfs.autoform.defaultIcon = field.defaultIcon\n\n\t\telse if field.type == \"select\"\n\t\t\tfs.type = String\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tfs.autoform.type = \"steedosLookups\"\n\t\t\t\tfs.autoform.showIcon = false\n\t\t\t\tfs.autoform.options = field.options\n\t\t\telse\n\t\t\t\tfs.autoform.type = \"select\"\n\t\t\t\tfs.autoform.options = field.options\n\t\t\t\tif _.has(field, 'firstOption')\n\t\t\t\t\tfs.autoform.firstOption = field.firstOption\n\t\t\t\telse\n\t\t\t\t\tfs.autoform.firstOption = \"\"\n\t\t\t# 因为列表视图右侧过滤器还是用的老表单的lookup和select控件,所以上面的代码始终保持原样需要执行\n\t\t\t# 下面是配置了data_type时,额外处理的逻辑\n\t\t\tif field.data_type and field.data_type != \"text\"\n\t\t\t\tif [\"number\", \"currency\", \"percent\"].indexOf(field.data_type) > -1\n\t\t\t\t\tfsType = Number\n\t\t\t\t\tfs.decimal = true\n\t\t\t\telse if field.data_type == \"boolean\"\n\t\t\t\t\tfsType = Boolean\n\t\t\t\telse\n\t\t\t\t\tfsType = String\n\t\t\t\tfs.type = fsType\n\t\t\t\tif field.multiple\n\t\t\t\t\tfs.type = [fsType]\n\t\t\t\t\t\n\t\t\t\tfs.autoform.options = Creator.getSelectOptions(field)\n\t\telse if field.type == \"currency\"\n\t\t\tfs.type = Number\n\t\t\tfs.autoform.type = \"steedosNumber\"\n\t\t\tfs.autoform.precision = field.precision || 18\n\t\t\tif field?.scale\n\t\t\t\tfs.autoform.scale = field.scale\n\t\t\t\tfs.decimal = true\n\t\t\telse if field?.scale != 0\n\t\t\t\tfs.autoform.scale = 2\n\t\t\t\tfs.decimal = true\n\t\telse if field.type == \"number\"\n\t\t\tfs.type = Number\n\t\t\tfs.autoform.type = \"steedosNumber\"\n\t\t\tfs.autoform.precision = field.precision || 18\n\t\t\tif field?.scale\n\t\t\t\tfs.autoform.scale = field.scale\n\t\t\t\tfs.decimal = true\n\t\telse if field.type == \"boolean\"\n\t\t\tfs.type = Boolean\n\t\t\tif field.readonly\n\t\t\t\tfs.autoform.disabled = true\n\t\t\tfs.autoform.type = \"steedos-boolean-checkbox\"\n\t\telse if field.type == \"toggle\"\n\t\t\tfs.type = Boolean\n\t\t\tif field.readonly\n\t\t\t\tfs.autoform.disabled = true\n\t\t\tfs.autoform.type = \"steedos-boolean-toggle\"\n\t\telse if field.type == \"reference\"\n\t\t\tfs.type = String\n\t\telse if field.type == \"checkbox\"\n\t\t\tfs.type = [String]\n\t\t\tfs.autoform.type = \"select-checkbox\"\n\t\t\tfs.autoform.options = field.options\n\t\telse if field.type == \"file\"\n\t\t\tcollectionName = field.collection || \"files\" # collection 默认是 'files'\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: collectionName\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = collectionName\n\t\telse if field.type == \"filesize\"\n\t\t\tfs.type = Number\n\t\t\tfs.autoform.type = 'filesize'\n\t\telse if field.type == \"Object\" || field.type == \"object\"\n\t\t\tfs.type = Object\n\t\telse if field.type == \"grid\" || field.type == \"table\"\n\t\t\tfs.type = Array\n\t\t\tfs.autoform.editable = true\n\t\t\tfs.autoform.type = \"steedosGrid\"\n\n\t\t\tschema[field_name + \".$\"] =\n\t\t\t\ttype: Object\n\t\telse if field.type == \"image\"\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: 'images'\n\t\t\t\t\t\taccept: 'image/*'\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = 'images'\n\t\t\t\tfs.autoform.accept = 'image/*'\n\t\telse if field.type == \"avatar\"\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: 'avatars'\n\t\t\t\t\t\taccept: 'image/*'\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = 'avatars'\n\t\t\t\tfs.autoform.accept = 'image/*'\n\t\telse if field.type == \"audio\"\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: 'audios'\n\t\t\t\t\t\taccept: 'audio/*'\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = 'audios'\n\t\t\t\tfs.autoform.accept = 'audio/*'\n\t\telse if field.type == \"video\"\n\t\t\tif field.multiple\n\t\t\t\tfs.type = [String]\n\t\t\t\tschema[field_name + \".$\"] =\n\t\t\t\t\tautoform:\n\t\t\t\t\t\ttype: 'fileUpload'\n\t\t\t\t\t\tcollection: 'videos'\n\t\t\t\t\t\taccept: 'video/*'\n\t\t\telse\n\t\t\t\tfs.type = String\n\t\t\t\tfs.autoform.type = 'fileUpload'\n\t\t\t\tfs.autoform.collection = 'videos'\n\t\t\t\tfs.autoform.accept = 'video/*'\n\t\telse if field.type == \"location\"\n\t\t\tfs.type = Object\n\t\t\tfs.autoform.type = \"location\"\n\t\t\tfs.autoform.system = field.system || \"wgs84\"\n\t\t\tfs.blackbox = true\n\t\telse if field.type == \"markdown\"\n\t\t\tfs.type = String\n\t\t\tfs.autoform.type = \"text\"\n\t\telse if field.type == 'url'\n\t\t\tfs.type = String\n\t\t\t# fs.regEx = SimpleSchema.RegEx.Url\n\t\t\tfs.autoform.type = 'steedosUrl'\n\t\telse if field.type == 'email'\n\t\t\tfs.type = String\n\t\t\tfs.regEx = SimpleSchema.RegEx.Email\n\t\t\tfs.autoform.type = 'steedosEmail'\n\t\telse if field.type == 'autonumber'\n\t\t\tfs.type = String\n\t\telse if field.type == 'color'\n\t\t\tfs.type = String\n\t\telse if field.type == 'formula'\n\t\t\tfs = Creator.getObjectSchema({fields: {field: Object.assign({}, field, {type: field.data_type})}})[field.name]\n\t\telse if field.type == 'summary'\n\t\t\tfs = Creator.getObjectSchema({fields: {field: Object.assign({}, field, {type: field.data_type})}})[field.name]\n\t\t# else if field.type == 'select'\n\t\t# \tfs = Creator.getObjectSchema({fields: {field: Object.assign({}, field, {type: field.data_type})}})[field.name]\n\t\telse if field.type == 'percent'\n\t\t\tfs.type = Number\n\t\t\tfs.autoform.type = \"steedosNumber\"\n\t\t\tfs.autoform.precision = field.precision || 18\n\t\t\tunless _.isNumber(field.scale)\n\t\t\t\t# 没配置小数位数则按小数位数0来处理,即默认显示为整数的百分比,比如20%,此时控件可以输入2位小数,转成百分比就是整数\n\t\t\t\tfield.scale = 0\n\t\t\t# autoform控件中小数位数始终比配置的位数多2位\n\t\t\tfs.autoform.scale = field.scale + 2\n\t\t\tfs.decimal = true\n\t\telse\n\t\t\tfs.type = field.type\n\n\t\tif field.label\n\t\t\tfs.label = field.label\n\n#\t\tif field.allowedValues\n#\t\t\tfs.allowedValues = field.allowedValues\n\n\t\tif !field.required\n\t\t\tfs.optional = true\n\n\t\t# [签约对象同时配置了company_ids必填及uneditable_fields造成部分用户新建签约对象时报错 #192](https://github.com/steedos/steedos-project-dzug/issues/192)\n\t\t# 后台始终设置required为false\n\t\tif !Meteor.isClient\n\t\t\tfs.optional = true\n\n\t\tif field.unique\n\t\t\tfs.unique = true\n\n\t\tif field.omit\n\t\t\tfs.autoform.omit = true\n\n\t\tif field.group\n\t\t\tfs.autoform.group = field.group\n\n\t\tif field.is_wide\n\t\t\tfs.autoform.is_wide = true\n\n\t\tif field.hidden\n\t\t\tfs.autoform.type = \"hidden\"\n\n\t\tif (field.type == \"select\") or (field.type == \"lookup\") or (field.type == \"master_detail\")\n\t\t\tif typeof(field.filterable) == 'undefined'\n\t\t\t\tfield.filterable = true\n\t\tif field.name == 'name' || field.is_name\n\t\t\tif typeof(field.searchable) == 'undefined'\n\t\t\t\tfield.searchable = true\n\n\t\tif autoform_type\n\t\t\tfs.autoform.type = autoform_type\n\n\t\tif field.defaultValue\n\t\t\tif Meteor.isClient and Creator.Formular.checkFormula(field.defaultValue)\n\t\t\t\tfs.autoform.defaultValue = ()->\n\t\t\t\t\treturn Creator.Formular.run(field.defaultValue, {userId: Meteor.userId(), spaceId: Session.get(\"spaceId\"), now: new Date()})\n\t\t\telse\n\t\t\t\tfs.autoform.defaultValue = field.defaultValue\n\t\t\t# \tif !_.isFunction(field.defaultValue)\n\t\t\t# \t\tfs.defaultValue = field.defaultValue\n\n\t\tif field.readonly\n\t\t\tfs.autoform.readonly = true\n\n\t\tif field.disabled\n\t\t\tfs.autoform.disabled = true\n\n\t\tif field.inlineHelpText\n\t\t\tfs.autoform.inlineHelpText = field.inlineHelpText\n\n\t\tif field.blackbox\n\t\t\tfs.blackbox = true\n\n\t\tif _.has(field, 'min')\n\t\t\tfs.min = field.min\n\t\tif _.has(field, 'max')\n\t\t\tfs.max = field.max\n\n\t\t# 只有生产环境才重建索引\n\t\tif Meteor.isProduction\n\t\t\tif field.index\n\t\t\t\tfs.index = field.index\n\t\t\telse if field.sortable\n\t\t\t\tfs.index = true\n\n\t\tschema[field_name] = fs\n\n\treturn schema\n\n\nCreator.getFieldDisplayValue = (object_name, field_name, field_value)->\n\thtml = field_value\n\tobject = Creator.getObject(object_name)\n\tif !object\n\t\treturn \"\"\n\tfield = object.fields(field_name)\n\tif !field\n\t\treturn \"\"\n\n\tif field.type == \"datetime\"\n\t\thtml = moment(this.val).format('YYYY-MM-DD H:mm')\n\telse if field.type == \"date\"\n\t\thtml = moment(this.val).format('YYYY-MM-DD')\n\n\treturn html\n\nCreator.checkFieldTypeSupportBetweenQuery = (field_type)->\n\treturn [\"date\", \"datetime\", \"time\", \"currency\", \"number\"].includes(field_type)\n\nCreator.pushBetweenBuiltinOptionals = (field_type, operations)->\n\tbuiltinValues = Creator.getBetweenBuiltinValues(field_type)\n\tif builtinValues\n\t\t_.forEach builtinValues, (builtinItem, key)->\n\t\t\toperations.push({label: builtinItem.label, value: key})\n\nCreator.getBetweenBuiltinValues = (field_type, is_check_only)->\n\t# 过滤器字段类型对应的内置选项\n\tif [\"date\", \"datetime\"].includes(field_type)\n\t\treturn Creator.getBetweenTimeBuiltinValues(is_check_only, field_type)\n\nCreator.getBetweenBuiltinValueItem = (field_type, key)->\n\t# 过滤器字段类型对应的内置选项\n\tif [\"date\", \"datetime\"].includes(field_type)\n\t\treturn Creator.getBetweenTimeBuiltinValueItem(field_type, key)\n\nCreator.getBetweenBuiltinOperation = (field_type, value)->\n\t# 根据过滤器的过滤值,获取对应的内置运算符\n\t# 比如value为last_year,返回between_time_last_year\n\tunless _.isString(value)\n\t\treturn\n\tbetweenBuiltinValues = Creator.getBetweenBuiltinValues(field_type)\n\tunless betweenBuiltinValues\n\t\treturn\n\tresult = null\n\t_.each betweenBuiltinValues, (item, operation)->\n\t\tif item.key == value\n\t\t\tresult = operation\n\treturn result\n\n# 如果只是为判断operation是否存在,则没必要计算values,传入is_check_only为true即可\nCreator.getBetweenTimeBuiltinValues = (is_check_only, field_type)->\n\t# 过滤器时间字段类型对应的内置选项\n\treturn {\n\t\t\"between_time_last_year\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_year\"),\n\t\t\"between_time_this_year\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_year\"),\n\t\t\"between_time_next_year\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_year\"),\n\t\t\"between_time_last_quarter\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_quarter\"),\n\t\t\"between_time_this_quarter\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_quarter\"),\n\t\t\"between_time_next_quarter\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_quarter\"),\n\t\t\"between_time_last_month\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_month\"),\n\t\t\"between_time_this_month\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_month\"),\n\t\t\"between_time_next_month\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_month\"),\n\t\t\"between_time_last_week\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_week\"),\n\t\t\"between_time_this_week\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_week\"),\n\t\t\"between_time_next_week\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_week\"),\n\t\t\"between_time_yestday\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"yestday\"),\n\t\t\"between_time_today\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"today\"),\n\t\t\"between_time_tomorrow\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"tomorrow\"),\n\t\t\"between_time_last_7_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_7_days\"),\n\t\t\"between_time_last_30_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_30_days\"),\n\t\t\"between_time_last_60_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_60_days\"),\n\t\t\"between_time_last_90_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_90_days\"),\n\t\t\"between_time_last_120_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_120_days\"),\n\t\t\"between_time_next_7_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_7_days\"),\n\t\t\"between_time_next_30_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_30_days\"),\n\t\t\"between_time_next_60_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_60_days\"),\n\t\t\"between_time_next_90_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_90_days\"),\n\t\t\"between_time_next_120_days\": if is_check_only then true else Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_120_days\")\n\t}\n\nCreator.getQuarterStartMonth = (month)->\n\tif !month\n\t\tmonth = new Date().getMonth()\n\t\n\tif month < 3\n\t\treturn 0\n\telse if month < 6\n\t\treturn 3\n\telse if month < 9\n\t\treturn 6\n\t\n\treturn 9\n\n\nCreator.getLastQuarterFirstDay = (year,month)->\n\tif !year\n\t\tyear = new Date().getFullYear()\n\tif !month\n\t\tmonth = new Date().getMonth()\n\t\n\tif month < 3\n\t\tyear--\n\t\tmonth = 9\n\telse if month < 6\n\t\tmonth = 0\n\telse if month < 9\n\t\tmonth = 3\n\telse \n\t\tmonth = 6\n\t\n\treturn new Date(year, month, 1)\n\t\n\nCreator.getNextQuarterFirstDay = (year,month)->\n\tif !year\n\t\tyear = new Date().getFullYear()\n\tif !month\n\t\tmonth = new Date().getMonth()\n\t\n\tif month < 3\n\t\tmonth = 3\n\telse if month < 6\n\t\tmonth = 6\n\telse if month < 9\n\t\tmonth = 9\n\telse\n\t\tyear++\n\t\tmonth = 0\n\t\n\treturn new Date(year, month, 1)\n\nCreator.getMonthDays = (year,month)->\n\tif month == 11\n\t\treturn 31\n\t\n\tmillisecond = 1000 * 60 * 60 * 24\n\tstartDate = new Date(year, month, 1)\n\tendDate = new Date(year, month+1, 1)\n\tdays = (endDate-startDate)/millisecond\n\treturn days\n\nCreator.getLastMonthFirstDay = (year, month)->\n\tif !year\n\t\tyear = new Date().getFullYear()\n\tif !month\n\t\tmonth = new Date().getMonth()\n\t\n\t# 月份为0代表本年的第一月\n\tif month == 0\n\t\tmonth = 11\n\t\tyear--\n\t\treturn new Date(year, month, 1)\n\t\n\t# 否则,只减去月份\n\tmonth--;\n\treturn new Date(year, month, 1)\n\t\nCreator.getBetweenTimeBuiltinValueItem = (field_type, key)->\n\t# 过滤器between运算符,现算日期/日期时间类型字段的values值\n\tnow = new Date()\n\t# 一天的毫秒数\n\tmillisecond = 1000 * 60 * 60 * 24\n\tyestday = new Date(now.getTime() - millisecond)\n\ttomorrow = new Date(now.getTime() + millisecond)\n\t# 一周中的某一天\n\tweek = now.getDay()\n\t# 减去的天数\n\tminusDay = if week != 0 then week - 1 else 6\n\tmonday = new Date(now.getTime() - (minusDay * millisecond))\n\tsunday = new Date(monday.getTime() + (6 * millisecond))\n\t# 上周日\n\tlastSunday = new Date(monday.getTime() - millisecond)\n\t# 上周一\n\tlastMonday = new Date(lastSunday.getTime() - (millisecond * 6))\n\t# 下周一\n\tnextMonday = new Date(sunday.getTime() + millisecond)\n\t# 下周日\n\tnextSunday = new Date(nextMonday.getTime() + (millisecond * 6))\n\tcurrentYear = now.getFullYear()\n\tpreviousYear = currentYear - 1\n\tnextYear = currentYear + 1\n\t# 当前月份\n\tcurrentMonth = now.getMonth()\n\t# 计数年、月\n\tyear = now.getFullYear()\n\tmonth = now.getMonth()\n\t# 本月第一天\n\tfirstDay = new Date(currentYear,currentMonth,1)\n\n\t# 当为12月的时候年份需要加1\n\t# 月份需要更新为0 也就是下一年的第一个月\n\tif currentMonth == 11\n\t\tyear++\n\t\tmonth++\n\telse\n\t\tmonth++\n\t\n\t# 下月第一天\n\tnextMonthFirstDay = new Date(year, month, 1)\n\t# 下月最后一天\n\tnextMonthFinalDay = new Date(year,month,Creator.getMonthDays(year,month))\n\t# 本月最后一天\n\tlastDay = new Date(nextMonthFirstDay.getTime() - millisecond)\n\t# 上月第一天\n\tlastMonthFirstDay = Creator.getLastMonthFirstDay(currentYear,currentMonth)\n\t# 上月最后一天\n\tlastMonthFinalDay = new Date(firstDay.getTime() - millisecond)\n\t# 本季度开始日\n\tthisQuarterStartDay = new Date(currentYear,Creator.getQuarterStartMonth(currentMonth),1)\n\t# 本季度结束日\n\tthisQuarterEndDay = new Date(currentYear,Creator.getQuarterStartMonth(currentMonth)+2,Creator.getMonthDays(currentYear,Creator.getQuarterStartMonth(currentMonth)+2))\n\t# 上季度开始日\n\tlastQuarterStartDay = Creator.getLastQuarterFirstDay(currentYear,currentMonth)\n\t# 上季度结束日\n\tlastQuarterEndDay = new Date(lastQuarterStartDay.getFullYear(),lastQuarterStartDay.getMonth()+2,Creator.getMonthDays(lastQuarterStartDay.getFullYear(),lastQuarterStartDay.getMonth()+2))\n\t# 下季度开始日\n\tnextQuarterStartDay = Creator.getNextQuarterFirstDay(currentYear,currentMonth)\n\t# 下季度结束日\n\tnextQuarterEndDay = new Date(nextQuarterStartDay.getFullYear(),nextQuarterStartDay.getMonth()+2,Creator.getMonthDays(nextQuarterStartDay.getFullYear(),nextQuarterStartDay.getMonth()+2))\n\t# 过去7天 \n\tlast_7_days = new Date(now.getTime() - (6 * millisecond))\n\t# 过去30天\n\tlast_30_days = new Date(now.getTime() - (29 * millisecond))\n\t# 过去60天\n\tlast_60_days = new Date(now.getTime() - (59 * millisecond))\n\t# 过去90天\n\tlast_90_days = new Date(now.getTime() - (89 * millisecond))\n\t# 过去120天\n\tlast_120_days = new Date(now.getTime() - (119 * millisecond))\n\t# 未来7天 \n\tnext_7_days = new Date(now.getTime() + (6 * millisecond))\n\t# 未来30天\n\tnext_30_days = new Date(now.getTime() + (29 * millisecond))\n\t# 未来60天\n\tnext_60_days = new Date(now.getTime() + (59 * millisecond))\n\t# 未来90天\n\tnext_90_days = new Date(now.getTime() + (89 * millisecond))\n\t# 未来120天\n\tnext_120_days = new Date(now.getTime() + (119 * millisecond))\n\n\tswitch key\n\t\twhen \"last_year\"\n\t\t\t#去年\n\t\t\tlabel = t(\"creator_filter_operation_between_last_year\")\n\t\t\tstartValue = new Date(\"#{previousYear}-01-01T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{previousYear}-12-31T23:59:59Z\")\n\t\twhen \"this_year\"\n\t\t\t#今年\n\t\t\tlabel = t(\"creator_filter_operation_between_this_year\")\n\t\t\tstartValue = new Date(\"#{currentYear}-01-01T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{currentYear}-12-31T23:59:59Z\")\n\t\twhen \"next_year\"\n\t\t\t#明年\n\t\t\tlabel = t(\"creator_filter_operation_between_next_year\")\n\t\t\tstartValue = new Date(\"#{nextYear}-01-01T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{nextYear}-12-31T23:59:59Z\")\n\t\twhen \"last_quarter\"\n\t\t\t#上季度\n\t\t\tstrFirstDay = moment(lastQuarterStartDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(lastQuarterEndDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_quarter\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"this_quarter\"\n\t\t\t#本季度\n\t\t\tstrFirstDay = moment(thisQuarterStartDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(thisQuarterEndDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_this_quarter\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"next_quarter\"\n\t\t\t#下季度\n\t\t\tstrFirstDay = moment(nextQuarterStartDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(nextQuarterEndDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_quarter\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"last_month\"\n\t\t\t#上月\n\t\t\tstrFirstDay = moment(lastMonthFirstDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(lastMonthFinalDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_month\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"this_month\"\n\t\t\t#本月\n\t\t\tstrFirstDay = moment(firstDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(lastDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_this_month\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"next_month\"\n\t\t\t#下月\n\t\t\tstrFirstDay = moment(nextMonthFirstDay).format(\"YYYY-MM-DD\")\n\t\t\tstrLastDay = moment(nextMonthFinalDay).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_month\")\n\t\t\tstartValue = new Date(\"#{strFirstDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strLastDay}T23:59:59Z\")\n\t\twhen \"last_week\"\n\t\t\t#上周\n\t\t\tstrMonday = moment(lastMonday).format(\"YYYY-MM-DD\")\n\t\t\tstrSunday = moment(lastSunday).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_week\")\n\t\t\tstartValue = new Date(\"#{strMonday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strSunday}T23:59:59Z\")\n\t\twhen \"this_week\"\n\t\t\t#本周\n\t\t\tstrMonday = moment(monday).format(\"YYYY-MM-DD\")\n\t\t\tstrSunday = moment(sunday).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_this_week\")\n\t\t\tstartValue = new Date(\"#{strMonday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strSunday}T23:59:59Z\")\n\t\twhen \"next_week\"\n\t\t\t#下周\n\t\t\tstrMonday = moment(nextMonday).format(\"YYYY-MM-DD\")\n\t\t\tstrSunday = moment(nextSunday).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_week\")\n\t\t\tstartValue = new Date(\"#{strMonday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strSunday}T23:59:59Z\")\n\t\twhen \"yestday\"\n\t\t\t#昨天\n\t\t\tstrYestday = moment(yestday).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_yestday\")\n\t\t\tstartValue = new Date(\"#{strYestday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strYestday}T23:59:59Z\")\n\t\twhen \"today\"\n\t\t\t#今天\n\t\t\tstrToday = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_today\")\n\t\t\tstartValue = new Date(\"#{strToday}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strToday}T23:59:59Z\")\n\t\twhen \"tomorrow\"\n\t\t\t#明天\n\t\t\tstrTomorrow = moment(tomorrow).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_tomorrow\")\n\t\t\tstartValue = new Date(\"#{strTomorrow}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strTomorrow}T23:59:59Z\")\n\t\twhen \"last_7_days\"\n\t\t\t#过去7天\n\t\t\tstrStartDay = moment(last_7_days).format(\"YYYY-MM-DD\") \n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_7_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"last_30_days\"\n\t\t\t#过去30天\n\t\t\tstrStartDay = moment(last_30_days).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_30_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"last_60_days\"\n\t\t\t#过去60天\n\t\t\tstrStartDay = moment(last_60_days).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_60_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"last_90_days\"\n\t\t\t#过去90天\n\t\t\tstrStartDay = moment(last_90_days).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_90_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"last_120_days\"\n\t\t\t#过去120天\n\t\t\tstrStartDay = moment(last_120_days).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_last_120_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_7_days\"\n\t\t\t#未来7天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_7_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_7_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_30_days\"\n\t\t\t#未来30天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_30_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_30_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_60_days\"\n\t\t\t#未来60天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_60_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_60_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_90_days\"\n\t\t\t#未来90天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_90_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_90_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\twhen \"next_120_days\"\n\t\t\t#未来120天\n\t\t\tstrStartDay = moment(now).format(\"YYYY-MM-DD\")\n\t\t\tstrEndDay = moment(next_120_days).format(\"YYYY-MM-DD\")\n\t\t\tlabel = t(\"creator_filter_operation_between_next_120_days\")\n\t\t\tstartValue = new Date(\"#{strStartDay}T00:00:00Z\")\n\t\t\tendValue = new Date(\"#{strEndDay}T23:59:59Z\")\n\t\n\tvalues = [startValue, endValue]\n\tif field_type == \"datetime\"\n\t\t# 时间类型字段,内置时间范围应该考虑偏移时区值,否则过滤数据存在偏差\n\t\t# 非内置时间范围时,用户通过时间控件选择的范围,会自动处理时区偏差情况\n\t\t# 日期类型字段,数据库本来就存的是UTC的0点,不存在偏差\n\t\t_.forEach values, (fv)->\n\t\t\tif fv\n\t\t\t\tfv.setHours(fv.getHours() + fv.getTimezoneOffset() / 60 )\n\t\n\treturn {\n\t\tlabel: label\n\t\tkey: key\n\t\tvalues: values\n\t}\n\nCreator.getFieldDefaultOperation = (field_type)->\n\tif field_type && Creator.checkFieldTypeSupportBetweenQuery(field_type)\n\t\treturn 'between'\n\telse if [\"textarea\", \"text\", \"code\"].includes(field_type)\n\t\treturn 'contains'\n\telse\n\t\treturn \"=\"\n\nCreator.getFieldOperation = (field_type) ->\n\t# 日期类型: date, datetime 支持操作符: \"=\", \"<>\", \"<\", \">\", \"<=\", \">=\"\n\t# 文本类型: text, textarea, html 支持操作符: \"=\", \"<>\", \"contains\", \"notcontains\", \"startswith\"\n\t# 选择类型: lookup, master_detail, select 支持操作符: \"=\", \"<>\"\n\t# 数值类型: currency, number 支持操作符: \"=\", \"<>\", \"<\", \">\", \"<=\", \">=\"\n\t# 布尔类型: boolean 支持操作符: \"=\", \"<>\"\n\t# 数组类型: checkbox, [text] 支持操作符: \"=\", \"<>\"\n\n\toptionals = {\n\t\tequal: {label: t(\"creator_filter_operation_equal\"), value: \"=\"},\n\t\tunequal: {label: t(\"creator_filter_operation_unequal\"), value: \"<>\"},\n\t\tless_than: {label: t(\"creator_filter_operation_less_than\"), value: \"<\"},\n\t\tgreater_than: {label: t(\"creator_filter_operation_greater_than\"), value: \">\"},\n\t\tless_or_equal: {label: t(\"creator_filter_operation_less_or_equal\"), value: \"<=\"},\n\t\tgreater_or_equal: {label: t(\"creator_filter_operation_greater_or_equal\"), value: \">=\"},\n\t\tcontains: {label: t(\"creator_filter_operation_contains\"), value: \"contains\"},\n\t\tnot_contain: {label: t(\"creator_filter_operation_does_not_contain\"), value: \"notcontains\"},\n\t\tstarts_with: {label: t(\"creator_filter_operation_starts_with\"), value: \"startswith\"},\n\t\tbetween: {label: t(\"creator_filter_operation_between\"), value: \"between\"},\n\t}\n\n\tif field_type == undefined\n\t\treturn _.values(optionals)\n\n\toperations = []\n\n\tif Creator.checkFieldTypeSupportBetweenQuery(field_type)\n\t\toperations.push(optionals.between)\n\t\tCreator.pushBetweenBuiltinOptionals(field_type, operations)\n\telse if field_type == \"text\" or field_type == \"textarea\" or field_type == \"html\" or field_type == \"code\"\n#\t\toperations.push(optionals.equal, optionals.unequal, optionals.contains, optionals.not_contain, optionals.starts_with)\n\t\toperations.push(optionals.contains)\n\telse if field_type == \"lookup\" or field_type == \"master_detail\" or field_type == \"select\"\n\t\toperations.push(optionals.equal, optionals.unequal)\n\telse if field_type == \"currency\" or field_type == \"number\"\n\t\toperations.push(optionals.equal, optionals.unequal, optionals.less_than, optionals.greater_than, optionals.less_or_equal, optionals.greater_or_equal)\n\telse if field_type == \"boolean\"\n\t\toperations.push(optionals.equal, optionals.unequal)\n\telse if field_type == \"checkbox\"\n\t\toperations.push(optionals.equal, optionals.unequal)\n\telse if field_type == \"[text]\"\n\t\toperations.push(optionals.equal, optionals.unequal)\n\telse\n\t\toperations.push(optionals.equal, optionals.unequal)\n\n\treturn operations\n\n###\n 先按照有排序号的小的在前,大的在后\n 再将没有排序号的显示在\n###\nCreator.getObjectFieldsName = (object_name)->\n\tfields = Creator.getObject(object_name)?.fields\n\tfieldsArr = []\n\n\t_.each fields, (field)->\n\t\tfieldsArr.push {name: field.name, sort_no: field.sort_no}\n\n\tfieldsName = []\n\t_.each _.sortBy(fieldsArr, \"sort_no\"), (field)->\n\t\tfieldsName.push(field.name)\n\treturn fieldsName\n","Creator.getSelectOptions = function(fieldSchema) {\n var data_type, options;\n options = fieldSchema.options;\n if (!options) {\n return;\n }\n data_type = fieldSchema.data_type;\n if (!_.isFunction(options) && data_type && data_type !== 'text') {\n options.forEach(function(optionItem) {\n if (typeof optionItem.value !== 'string') {\n return;\n }\n if (['number', 'currency', 'percent'].indexOf(data_type) > -1) {\n return optionItem.value = Number(optionItem.value);\n } else if (data_type === 'boolean') {\n return optionItem.value = optionItem.value === 'true';\n }\n });\n }\n return options;\n};\n\nCreator.getObjectSchema = function(obj) {\n var fieldsArr, schema;\n if (!obj) {\n return;\n }\n schema = {};\n fieldsArr = [];\n _.each(obj.fields, function(field, field_name) {\n if (!_.has(field, \"name\")) {\n field.name = field_name;\n }\n return fieldsArr.push(field);\n });\n _.each(_.sortBy(fieldsArr, \"sort_no\"), function(field) {\n var _object, _ref_obj, _reference_to, autoform_type, collectionName, field_name, fs, fsType, isUnLimited, permissions, ref, ref1;\n field_name = field.name;\n fs = {};\n if (field.regEx) {\n fs.regEx = field.regEx;\n }\n fs.autoform = {};\n fs.autoform.multiple = field.multiple;\n fs.autoform.reference_to = field.reference_to;\n autoform_type = (ref = field.autoform) != null ? ref.type : void 0;\n if (field.type === \"text\" || field.type === \"phone\") {\n fs.type = String;\n if (field.multiple) {\n fs.type = [String];\n fs.autoform.type = \"tags\";\n }\n } else if (field.type === \"[text]\" || field.type === \"[phone]\") {\n fs.type = [String];\n fs.autoform.type = \"tags\";\n } else if (field.type === 'code') {\n fs.type = String;\n fs.autoform.type = \"widearea\";\n fs.autoform.rows = field.rows || 12;\n if (field.language) {\n fs.autoform.language = field.language;\n }\n } else if (field.type === \"textarea\") {\n fs.type = String;\n fs.autoform.type = \"widearea\";\n fs.autoform.rows = field.rows || 2;\n } else if (field.type === \"password\") {\n fs.type = String;\n fs.autoform.type = \"password\";\n } else if (field.type === \"date\") {\n fs.type = Date;\n if (Meteor.isClient) {\n if (Steedos.isMobile() || Steedos.isPad()) {\n if (Steedos.isiOS()) {\n fs.autoform.afFieldInput = {\n type: \"dx-date-box\",\n timezoneId: \"utc\",\n dxDateBoxOptions: {\n type: \"date\",\n displayFormat: \"yyyy-MM-dd\",\n pickerType: \"rollers\"\n }\n };\n } else {\n fs.autoform.afFieldInput = {\n type: \"steedos-date-mobile\",\n dateMobileOptions: {\n type: \"date\"\n }\n };\n }\n } else {\n fs.autoform.outFormat = 'yyyy-MM-dd';\n fs.autoform.afFieldInput = {\n type: \"dx-date-box\",\n timezoneId: \"utc\",\n dxDateBoxOptions: {\n type: \"date\",\n displayFormat: \"yyyy-MM-dd\"\n }\n };\n }\n }\n } else if (field.type === \"time\") {\n fs.type = Date;\n if (Meteor.isClient) {\n fs.autoform.afFieldInput = {\n type: \"dx-date-box\",\n timezoneId: \"utc\",\n dxDateBoxOptions: {\n type: \"time\",\n displayFormat: \"HH:mm\"\n }\n };\n }\n } else if (field.type === \"datetime\") {\n fs.type = Date;\n if (Meteor.isClient) {\n if (Steedos.isMobile() || Steedos.isPad()) {\n if (Steedos.isiOS()) {\n fs.autoform.afFieldInput = {\n type: \"dx-date-box\",\n dxDateBoxOptions: {\n type: \"datetime\",\n displayFormat: \"yyyy-MM-dd HH:mm\",\n pickerType: \"rollers\"\n }\n };\n } else {\n fs.autoform.afFieldInput = {\n type: \"steedos-date-mobile\",\n dateMobileOptions: {\n type: \"datetime\"\n }\n };\n }\n } else {\n fs.autoform.afFieldInput = {\n type: \"dx-date-box\",\n dxDateBoxOptions: {\n type: \"datetime\",\n displayFormat: \"yyyy-MM-dd HH:mm\"\n }\n };\n }\n }\n } else if (field.type === \"[Object]\") {\n fs.type = [Object];\n } else if (field.type === \"html\") {\n fs.type = String;\n if (Meteor.isClient) {\n fs.autoform.type = 'steedosHtml';\n }\n } else if (field.type === \"lookup\" || field.type === \"master_detail\") {\n fs.type = String;\n fs.autoform.showIcon = field.showIcon;\n if (field.multiple) {\n fs.type = [String];\n }\n if (!field.hidden) {\n fs.autoform.filters = field.filters;\n fs.autoform.dependOn = field.depend_on;\n if (field.beforeOpenFunction) {\n fs.beforeOpenFunction = field.beforeOpenFunction;\n }\n fs.filtersFunction = field.filtersFunction ? field.filtersFunction : Creator.evaluateFilters;\n if (field.optionsFunction) {\n fs.optionsFunction = field.optionsFunction;\n }\n if (field.reference_to) {\n if (Meteor.isClient) {\n if (field.createFunction && _.isFunction(field.createFunction)) {\n fs.createFunction = field.createFunction;\n } else {\n if (_.isString(field.reference_to)) {\n _ref_obj = Creator.Objects[field.reference_to];\n if (_ref_obj != null ? (ref1 = _ref_obj.permissions) != null ? ref1.allowCreate : void 0 : void 0) {\n fs.autoform.create = true;\n fs.createFunction = function(lookup_field) {\n return Modal.show(\"CreatorObjectModal\", {\n collection: \"Creator.Collections.\" + (Creator.getCollection(field.reference_to)._name),\n formId: \"new\" + (field.reference_to.replace('.', '_')),\n object_name: \"\" + field.reference_to,\n operation: \"insert\",\n onSuccess: function(operation, result) {\n var object;\n object = Creator.getObject(result.object_name);\n if (result.object_name === \"objects\") {\n return lookup_field.addItems([\n {\n label: result.value.label,\n value: result.value.name,\n icon: result.value.icon\n }\n ], result.value.name);\n } else {\n return lookup_field.addItems([\n {\n label: result.value[object.NAME_FIELD_KEY] || result.value.label || result.value.name,\n value: result._id\n }\n ], result._id);\n }\n }\n });\n };\n } else {\n fs.autoform.create = false;\n }\n }\n }\n }\n if (_.isBoolean(field.create)) {\n fs.autoform.create = field.create;\n }\n if (field.reference_sort) {\n fs.autoform.optionsSort = field.reference_sort;\n }\n if (field.reference_limit) {\n fs.autoform.optionsLimit = field.reference_limit;\n }\n if (field.reference_to_field) {\n fs.autoform.referenceToField = field.reference_to_field;\n }\n if (field.reference_to === \"users\") {\n fs.autoform.type = \"selectuser\";\n if (!field.hidden && !field.omit) {\n if (field.is_company_limited === void 0) {\n if (Meteor.isClient) {\n permissions = obj.permissions;\n isUnLimited = permissions != null ? permissions.viewAllRecords : void 0;\n if (_.include([\"organizations\", \"users\", \"space_users\"], obj.name)) {\n isUnLimited = permissions != null ? permissions.modifyAllRecords : void 0;\n }\n if (isUnLimited) {\n fs.autoform.is_company_limited = false;\n } else {\n fs.autoform.is_company_limited = true;\n }\n }\n } else if (_.isFunction(field.is_company_limited)) {\n if (Meteor.isClient) {\n fs.autoform.is_company_limited = field.is_company_limited(obj.permissions);\n } else {\n fs.autoform.is_company_limited = true;\n }\n } else {\n fs.autoform.is_company_limited = field.is_company_limited;\n }\n } else {\n fs.autoform.is_company_limited = field.is_company_limited;\n }\n } else if (field.reference_to === \"organizations\") {\n fs.autoform.type = \"selectorg\";\n if (!field.hidden && !field.omit) {\n if (field.is_company_limited === void 0) {\n if (Meteor.isClient) {\n permissions = obj.permissions;\n isUnLimited = permissions != null ? permissions.viewAllRecords : void 0;\n if (_.include([\"organizations\", \"users\", \"space_users\"], obj.name)) {\n isUnLimited = permissions != null ? permissions.modifyAllRecords : void 0;\n }\n if (isUnLimited) {\n fs.autoform.is_company_limited = false;\n } else {\n fs.autoform.is_company_limited = true;\n }\n }\n } else if (_.isFunction(field.is_company_limited)) {\n if (Meteor.isClient) {\n fs.autoform.is_company_limited = field.is_company_limited(obj.permissions);\n } else {\n fs.autoform.is_company_limited = true;\n }\n } else {\n fs.autoform.is_company_limited = field.is_company_limited;\n }\n } else {\n fs.autoform.is_company_limited = field.is_company_limited;\n }\n } else {\n if (typeof field.reference_to === \"function\") {\n _reference_to = field.reference_to();\n } else {\n _reference_to = field.reference_to;\n }\n if (_.isArray(_reference_to)) {\n fs.type = Object;\n fs.blackbox = true;\n fs.autoform.objectSwitche = true;\n schema[field_name + \".o\"] = {\n type: String,\n autoform: {\n omit: true\n }\n };\n schema[field_name + \".ids\"] = {\n type: [String],\n autoform: {\n omit: true\n }\n };\n } else {\n _reference_to = [_reference_to];\n }\n _object = Creator.Objects[_reference_to[0]];\n if (_object && _object.enable_tree) {\n fs.autoform.type = \"selectTree\";\n } else {\n fs.autoform.type = \"steedosLookups\";\n fs.autoform.optionsMethod = field.optionsMethod || \"creator.object_options\";\n if (Meteor.isClient) {\n fs.autoform.optionsMethodParams = function() {\n return {\n space: Session.get(\"spaceId\")\n };\n };\n fs.autoform.references = [];\n _reference_to.forEach(function(_reference) {\n _object = Creator.Objects[_reference];\n if (_object) {\n return fs.autoform.references.push({\n object: _reference,\n label: _object != null ? _object.label : void 0,\n icon: _object != null ? _object.icon : void 0,\n link: function() {\n return \"/app/\" + (Session.get('app_id')) + \"/\" + _reference + \"/view/\";\n }\n });\n } else {\n return fs.autoform.references.push({\n object: _reference,\n link: function() {\n return \"/app/\" + (Session.get('app_id')) + \"/\" + _reference + \"/view/\";\n }\n });\n }\n });\n }\n }\n }\n } else {\n fs.autoform.type = \"steedosLookups\";\n fs.autoform.defaultIcon = field.defaultIcon;\n }\n }\n } else if (field.type === \"select\") {\n fs.type = String;\n if (field.multiple) {\n fs.type = [String];\n fs.autoform.type = \"steedosLookups\";\n fs.autoform.showIcon = false;\n fs.autoform.options = field.options;\n } else {\n fs.autoform.type = \"select\";\n fs.autoform.options = field.options;\n if (_.has(field, 'firstOption')) {\n fs.autoform.firstOption = field.firstOption;\n } else {\n fs.autoform.firstOption = \"\";\n }\n }\n if (field.data_type && field.data_type !== \"text\") {\n if ([\"number\", \"currency\", \"percent\"].indexOf(field.data_type) > -1) {\n fsType = Number;\n fs.decimal = true;\n } else if (field.data_type === \"boolean\") {\n fsType = Boolean;\n } else {\n fsType = String;\n }\n fs.type = fsType;\n if (field.multiple) {\n fs.type = [fsType];\n }\n fs.autoform.options = Creator.getSelectOptions(field);\n }\n } else if (field.type === \"currency\") {\n fs.type = Number;\n fs.autoform.type = \"steedosNumber\";\n fs.autoform.precision = field.precision || 18;\n if (field != null ? field.scale : void 0) {\n fs.autoform.scale = field.scale;\n fs.decimal = true;\n } else if ((field != null ? field.scale : void 0) !== 0) {\n fs.autoform.scale = 2;\n fs.decimal = true;\n }\n } else if (field.type === \"number\") {\n fs.type = Number;\n fs.autoform.type = \"steedosNumber\";\n fs.autoform.precision = field.precision || 18;\n if (field != null ? field.scale : void 0) {\n fs.autoform.scale = field.scale;\n fs.decimal = true;\n }\n } else if (field.type === \"boolean\") {\n fs.type = Boolean;\n if (field.readonly) {\n fs.autoform.disabled = true;\n }\n fs.autoform.type = \"steedos-boolean-checkbox\";\n } else if (field.type === \"toggle\") {\n fs.type = Boolean;\n if (field.readonly) {\n fs.autoform.disabled = true;\n }\n fs.autoform.type = \"steedos-boolean-toggle\";\n } else if (field.type === \"reference\") {\n fs.type = String;\n } else if (field.type === \"checkbox\") {\n fs.type = [String];\n fs.autoform.type = \"select-checkbox\";\n fs.autoform.options = field.options;\n } else if (field.type === \"file\") {\n collectionName = field.collection || \"files\";\n if (field.multiple) {\n fs.type = [String];\n schema[field_name + \".$\"] = {\n autoform: {\n type: 'fileUpload',\n collection: collectionName\n }\n };\n } else {\n fs.type = String;\n fs.autoform.type = 'fileUpload';\n fs.autoform.collection = collectionName;\n }\n } else if (field.type === \"filesize\") {\n fs.type = Number;\n fs.autoform.type = 'filesize';\n } else if (field.type === \"Object\" || field.type === \"object\") {\n fs.type = Object;\n } else if (field.type === \"grid\" || field.type === \"table\") {\n fs.type = Array;\n fs.autoform.editable = true;\n fs.autoform.type = \"steedosGrid\";\n schema[field_name + \".$\"] = {\n type: Object\n };\n } else if (field.type === \"image\") {\n if (field.multiple) {\n fs.type = [String];\n schema[field_name + \".$\"] = {\n autoform: {\n type: 'fileUpload',\n collection: 'images',\n accept: 'image/*'\n }\n };\n } else {\n fs.type = String;\n fs.autoform.type = 'fileUpload';\n fs.autoform.collection = 'images';\n fs.autoform.accept = 'image/*';\n }\n } else if (field.type === \"avatar\") {\n if (field.multiple) {\n fs.type = [String];\n schema[field_name + \".$\"] = {\n autoform: {\n type: 'fileUpload',\n collection: 'avatars',\n accept: 'image/*'\n }\n };\n } else {\n fs.type = String;\n fs.autoform.type = 'fileUpload';\n fs.autoform.collection = 'avatars';\n fs.autoform.accept = 'image/*';\n }\n } else if (field.type === \"audio\") {\n if (field.multiple) {\n fs.type = [String];\n schema[field_name + \".$\"] = {\n autoform: {\n type: 'fileUpload',\n collection: 'audios',\n accept: 'audio/*'\n }\n };\n } else {\n fs.type = String;\n fs.autoform.type = 'fileUpload';\n fs.autoform.collection = 'audios';\n fs.autoform.accept = 'audio/*';\n }\n } else if (field.type === \"video\") {\n if (field.multiple) {\n fs.type = [String];\n schema[field_name + \".$\"] = {\n autoform: {\n type: 'fileUpload',\n collection: 'videos',\n accept: 'video/*'\n }\n };\n } else {\n fs.type = String;\n fs.autoform.type = 'fileUpload';\n fs.autoform.collection = 'videos';\n fs.autoform.accept = 'video/*';\n }\n } else if (field.type === \"location\") {\n fs.type = Object;\n fs.autoform.type = \"location\";\n fs.autoform.system = field.system || \"wgs84\";\n fs.blackbox = true;\n } else if (field.type === \"markdown\") {\n fs.type = String;\n fs.autoform.type = \"text\";\n } else if (field.type === 'url') {\n fs.type = String;\n fs.autoform.type = 'steedosUrl';\n } else if (field.type === 'email') {\n fs.type = String;\n fs.regEx = SimpleSchema.RegEx.Email;\n fs.autoform.type = 'steedosEmail';\n } else if (field.type === 'autonumber') {\n fs.type = String;\n } else if (field.type === 'color') {\n fs.type = String;\n } else if (field.type === 'formula') {\n fs = Creator.getObjectSchema({\n fields: {\n field: Object.assign({}, field, {\n type: field.data_type\n })\n }\n })[field.name];\n } else if (field.type === 'summary') {\n fs = Creator.getObjectSchema({\n fields: {\n field: Object.assign({}, field, {\n type: field.data_type\n })\n }\n })[field.name];\n } else if (field.type === 'percent') {\n fs.type = Number;\n fs.autoform.type = \"steedosNumber\";\n fs.autoform.precision = field.precision || 18;\n if (!_.isNumber(field.scale)) {\n field.scale = 0;\n }\n fs.autoform.scale = field.scale + 2;\n fs.decimal = true;\n } else {\n fs.type = field.type;\n }\n if (field.label) {\n fs.label = field.label;\n }\n if (!field.required) {\n fs.optional = true;\n }\n if (!Meteor.isClient) {\n fs.optional = true;\n }\n if (field.unique) {\n fs.unique = true;\n }\n if (field.omit) {\n fs.autoform.omit = true;\n }\n if (field.group) {\n fs.autoform.group = field.group;\n }\n if (field.is_wide) {\n fs.autoform.is_wide = true;\n }\n if (field.hidden) {\n fs.autoform.type = \"hidden\";\n }\n if ((field.type === \"select\") || (field.type === \"lookup\") || (field.type === \"master_detail\")) {\n if (typeof field.filterable === 'undefined') {\n field.filterable = true;\n }\n }\n if (field.name === 'name' || field.is_name) {\n if (typeof field.searchable === 'undefined') {\n field.searchable = true;\n }\n }\n if (autoform_type) {\n fs.autoform.type = autoform_type;\n }\n if (field.defaultValue) {\n if (Meteor.isClient && Creator.Formular.checkFormula(field.defaultValue)) {\n fs.autoform.defaultValue = function() {\n return Creator.Formular.run(field.defaultValue, {\n userId: Meteor.userId(),\n spaceId: Session.get(\"spaceId\"),\n now: new Date()\n });\n };\n } else {\n fs.autoform.defaultValue = field.defaultValue;\n }\n }\n if (field.readonly) {\n fs.autoform.readonly = true;\n }\n if (field.disabled) {\n fs.autoform.disabled = true;\n }\n if (field.inlineHelpText) {\n fs.autoform.inlineHelpText = field.inlineHelpText;\n }\n if (field.blackbox) {\n fs.blackbox = true;\n }\n if (_.has(field, 'min')) {\n fs.min = field.min;\n }\n if (_.has(field, 'max')) {\n fs.max = field.max;\n }\n if (Meteor.isProduction) {\n if (field.index) {\n fs.index = field.index;\n } else if (field.sortable) {\n fs.index = true;\n }\n }\n return schema[field_name] = fs;\n });\n return schema;\n};\n\nCreator.getFieldDisplayValue = function(object_name, field_name, field_value) {\n var field, html, object;\n html = field_value;\n object = Creator.getObject(object_name);\n if (!object) {\n return \"\";\n }\n field = object.fields(field_name);\n if (!field) {\n return \"\";\n }\n if (field.type === \"datetime\") {\n html = moment(this.val).format('YYYY-MM-DD H:mm');\n } else if (field.type === \"date\") {\n html = moment(this.val).format('YYYY-MM-DD');\n }\n return html;\n};\n\nCreator.checkFieldTypeSupportBetweenQuery = function(field_type) {\n return [\"date\", \"datetime\", \"time\", \"currency\", \"number\"].includes(field_type);\n};\n\nCreator.pushBetweenBuiltinOptionals = function(field_type, operations) {\n var builtinValues;\n builtinValues = Creator.getBetweenBuiltinValues(field_type);\n if (builtinValues) {\n return _.forEach(builtinValues, function(builtinItem, key) {\n return operations.push({\n label: builtinItem.label,\n value: key\n });\n });\n }\n};\n\nCreator.getBetweenBuiltinValues = function(field_type, is_check_only) {\n if ([\"date\", \"datetime\"].includes(field_type)) {\n return Creator.getBetweenTimeBuiltinValues(is_check_only, field_type);\n }\n};\n\nCreator.getBetweenBuiltinValueItem = function(field_type, key) {\n if ([\"date\", \"datetime\"].includes(field_type)) {\n return Creator.getBetweenTimeBuiltinValueItem(field_type, key);\n }\n};\n\nCreator.getBetweenBuiltinOperation = function(field_type, value) {\n var betweenBuiltinValues, result;\n if (!_.isString(value)) {\n return;\n }\n betweenBuiltinValues = Creator.getBetweenBuiltinValues(field_type);\n if (!betweenBuiltinValues) {\n return;\n }\n result = null;\n _.each(betweenBuiltinValues, function(item, operation) {\n if (item.key === value) {\n return result = operation;\n }\n });\n return result;\n};\n\nCreator.getBetweenTimeBuiltinValues = function(is_check_only, field_type) {\n return {\n \"between_time_last_year\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_year\"),\n \"between_time_this_year\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_year\"),\n \"between_time_next_year\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_year\"),\n \"between_time_last_quarter\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_quarter\"),\n \"between_time_this_quarter\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_quarter\"),\n \"between_time_next_quarter\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_quarter\"),\n \"between_time_last_month\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_month\"),\n \"between_time_this_month\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_month\"),\n \"between_time_next_month\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_month\"),\n \"between_time_last_week\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_week\"),\n \"between_time_this_week\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"this_week\"),\n \"between_time_next_week\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_week\"),\n \"between_time_yestday\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"yestday\"),\n \"between_time_today\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"today\"),\n \"between_time_tomorrow\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"tomorrow\"),\n \"between_time_last_7_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_7_days\"),\n \"between_time_last_30_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_30_days\"),\n \"between_time_last_60_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_60_days\"),\n \"between_time_last_90_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_90_days\"),\n \"between_time_last_120_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"last_120_days\"),\n \"between_time_next_7_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_7_days\"),\n \"between_time_next_30_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_30_days\"),\n \"between_time_next_60_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_60_days\"),\n \"between_time_next_90_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_90_days\"),\n \"between_time_next_120_days\": is_check_only ? true : Creator.getBetweenTimeBuiltinValueItem(field_type, \"next_120_days\")\n };\n};\n\nCreator.getQuarterStartMonth = function(month) {\n if (!month) {\n month = new Date().getMonth();\n }\n if (month < 3) {\n return 0;\n } else if (month < 6) {\n return 3;\n } else if (month < 9) {\n return 6;\n }\n return 9;\n};\n\nCreator.getLastQuarterFirstDay = function(year, month) {\n if (!year) {\n year = new Date().getFullYear();\n }\n if (!month) {\n month = new Date().getMonth();\n }\n if (month < 3) {\n year--;\n month = 9;\n } else if (month < 6) {\n month = 0;\n } else if (month < 9) {\n month = 3;\n } else {\n month = 6;\n }\n return new Date(year, month, 1);\n};\n\nCreator.getNextQuarterFirstDay = function(year, month) {\n if (!year) {\n year = new Date().getFullYear();\n }\n if (!month) {\n month = new Date().getMonth();\n }\n if (month < 3) {\n month = 3;\n } else if (month < 6) {\n month = 6;\n } else if (month < 9) {\n month = 9;\n } else {\n year++;\n month = 0;\n }\n return new Date(year, month, 1);\n};\n\nCreator.getMonthDays = function(year, month) {\n var days, endDate, millisecond, startDate;\n if (month === 11) {\n return 31;\n }\n millisecond = 1000 * 60 * 60 * 24;\n startDate = new Date(year, month, 1);\n endDate = new Date(year, month + 1, 1);\n days = (endDate - startDate) / millisecond;\n return days;\n};\n\nCreator.getLastMonthFirstDay = function(year, month) {\n if (!year) {\n year = new Date().getFullYear();\n }\n if (!month) {\n month = new Date().getMonth();\n }\n if (month === 0) {\n month = 11;\n year--;\n return new Date(year, month, 1);\n }\n month--;\n return new Date(year, month, 1);\n};\n\nCreator.getBetweenTimeBuiltinValueItem = function(field_type, key) {\n var currentMonth, currentYear, endValue, firstDay, label, lastDay, lastMonday, lastMonthFinalDay, lastMonthFirstDay, lastQuarterEndDay, lastQuarterStartDay, lastSunday, last_120_days, last_30_days, last_60_days, last_7_days, last_90_days, millisecond, minusDay, monday, month, nextMonday, nextMonthFinalDay, nextMonthFirstDay, nextQuarterEndDay, nextQuarterStartDay, nextSunday, nextYear, next_120_days, next_30_days, next_60_days, next_7_days, next_90_days, now, previousYear, startValue, strEndDay, strFirstDay, strLastDay, strMonday, strStartDay, strSunday, strToday, strTomorrow, strYestday, sunday, thisQuarterEndDay, thisQuarterStartDay, tomorrow, values, week, year, yestday;\n now = new Date();\n millisecond = 1000 * 60 * 60 * 24;\n yestday = new Date(now.getTime() - millisecond);\n tomorrow = new Date(now.getTime() + millisecond);\n week = now.getDay();\n minusDay = week !== 0 ? week - 1 : 6;\n monday = new Date(now.getTime() - (minusDay * millisecond));\n sunday = new Date(monday.getTime() + (6 * millisecond));\n lastSunday = new Date(monday.getTime() - millisecond);\n lastMonday = new Date(lastSunday.getTime() - (millisecond * 6));\n nextMonday = new Date(sunday.getTime() + millisecond);\n nextSunday = new Date(nextMonday.getTime() + (millisecond * 6));\n currentYear = now.getFullYear();\n previousYear = currentYear - 1;\n nextYear = currentYear + 1;\n currentMonth = now.getMonth();\n year = now.getFullYear();\n month = now.getMonth();\n firstDay = new Date(currentYear, currentMonth, 1);\n if (currentMonth === 11) {\n year++;\n month++;\n } else {\n month++;\n }\n nextMonthFirstDay = new Date(year, month, 1);\n nextMonthFinalDay = new Date(year, month, Creator.getMonthDays(year, month));\n lastDay = new Date(nextMonthFirstDay.getTime() - millisecond);\n lastMonthFirstDay = Creator.getLastMonthFirstDay(currentYear, currentMonth);\n lastMonthFinalDay = new Date(firstDay.getTime() - millisecond);\n thisQuarterStartDay = new Date(currentYear, Creator.getQuarterStartMonth(currentMonth), 1);\n thisQuarterEndDay = new Date(currentYear, Creator.getQuarterStartMonth(currentMonth) + 2, Creator.getMonthDays(currentYear, Creator.getQuarterStartMonth(currentMonth) + 2));\n lastQuarterStartDay = Creator.getLastQuarterFirstDay(currentYear, currentMonth);\n lastQuarterEndDay = new Date(lastQuarterStartDay.getFullYear(), lastQuarterStartDay.getMonth() + 2, Creator.getMonthDays(lastQuarterStartDay.getFullYear(), lastQuarterStartDay.getMonth() + 2));\n nextQuarterStartDay = Creator.getNextQuarterFirstDay(currentYear, currentMonth);\n nextQuarterEndDay = new Date(nextQuarterStartDay.getFullYear(), nextQuarterStartDay.getMonth() + 2, Creator.getMonthDays(nextQuarterStartDay.getFullYear(), nextQuarterStartDay.getMonth() + 2));\n last_7_days = new Date(now.getTime() - (6 * millisecond));\n last_30_days = new Date(now.getTime() - (29 * millisecond));\n last_60_days = new Date(now.getTime() - (59 * millisecond));\n last_90_days = new Date(now.getTime() - (89 * millisecond));\n last_120_days = new Date(now.getTime() - (119 * millisecond));\n next_7_days = new Date(now.getTime() + (6 * millisecond));\n next_30_days = new Date(now.getTime() + (29 * millisecond));\n next_60_days = new Date(now.getTime() + (59 * millisecond));\n next_90_days = new Date(now.getTime() + (89 * millisecond));\n next_120_days = new Date(now.getTime() + (119 * millisecond));\n switch (key) {\n case \"last_year\":\n label = t(\"creator_filter_operation_between_last_year\");\n startValue = new Date(previousYear + \"-01-01T00:00:00Z\");\n endValue = new Date(previousYear + \"-12-31T23:59:59Z\");\n break;\n case \"this_year\":\n label = t(\"creator_filter_operation_between_this_year\");\n startValue = new Date(currentYear + \"-01-01T00:00:00Z\");\n endValue = new Date(currentYear + \"-12-31T23:59:59Z\");\n break;\n case \"next_year\":\n label = t(\"creator_filter_operation_between_next_year\");\n startValue = new Date(nextYear + \"-01-01T00:00:00Z\");\n endValue = new Date(nextYear + \"-12-31T23:59:59Z\");\n break;\n case \"last_quarter\":\n strFirstDay = moment(lastQuarterStartDay).format(\"YYYY-MM-DD\");\n strLastDay = moment(lastQuarterEndDay).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_last_quarter\");\n startValue = new Date(strFirstDay + \"T00:00:00Z\");\n endValue = new Date(strLastDay + \"T23:59:59Z\");\n break;\n case \"this_quarter\":\n strFirstDay = moment(thisQuarterStartDay).format(\"YYYY-MM-DD\");\n strLastDay = moment(thisQuarterEndDay).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_this_quarter\");\n startValue = new Date(strFirstDay + \"T00:00:00Z\");\n endValue = new Date(strLastDay + \"T23:59:59Z\");\n break;\n case \"next_quarter\":\n strFirstDay = moment(nextQuarterStartDay).format(\"YYYY-MM-DD\");\n strLastDay = moment(nextQuarterEndDay).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_next_quarter\");\n startValue = new Date(strFirstDay + \"T00:00:00Z\");\n endValue = new Date(strLastDay + \"T23:59:59Z\");\n break;\n case \"last_month\":\n strFirstDay = moment(lastMonthFirstDay).format(\"YYYY-MM-DD\");\n strLastDay = moment(lastMonthFinalDay).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_last_month\");\n startValue = new Date(strFirstDay + \"T00:00:00Z\");\n endValue = new Date(strLastDay + \"T23:59:59Z\");\n break;\n case \"this_month\":\n strFirstDay = moment(firstDay).format(\"YYYY-MM-DD\");\n strLastDay = moment(lastDay).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_this_month\");\n startValue = new Date(strFirstDay + \"T00:00:00Z\");\n endValue = new Date(strLastDay + \"T23:59:59Z\");\n break;\n case \"next_month\":\n strFirstDay = moment(nextMonthFirstDay).format(\"YYYY-MM-DD\");\n strLastDay = moment(nextMonthFinalDay).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_next_month\");\n startValue = new Date(strFirstDay + \"T00:00:00Z\");\n endValue = new Date(strLastDay + \"T23:59:59Z\");\n break;\n case \"last_week\":\n strMonday = moment(lastMonday).format(\"YYYY-MM-DD\");\n strSunday = moment(lastSunday).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_last_week\");\n startValue = new Date(strMonday + \"T00:00:00Z\");\n endValue = new Date(strSunday + \"T23:59:59Z\");\n break;\n case \"this_week\":\n strMonday = moment(monday).format(\"YYYY-MM-DD\");\n strSunday = moment(sunday).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_this_week\");\n startValue = new Date(strMonday + \"T00:00:00Z\");\n endValue = new Date(strSunday + \"T23:59:59Z\");\n break;\n case \"next_week\":\n strMonday = moment(nextMonday).format(\"YYYY-MM-DD\");\n strSunday = moment(nextSunday).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_next_week\");\n startValue = new Date(strMonday + \"T00:00:00Z\");\n endValue = new Date(strSunday + \"T23:59:59Z\");\n break;\n case \"yestday\":\n strYestday = moment(yestday).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_yestday\");\n startValue = new Date(strYestday + \"T00:00:00Z\");\n endValue = new Date(strYestday + \"T23:59:59Z\");\n break;\n case \"today\":\n strToday = moment(now).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_today\");\n startValue = new Date(strToday + \"T00:00:00Z\");\n endValue = new Date(strToday + \"T23:59:59Z\");\n break;\n case \"tomorrow\":\n strTomorrow = moment(tomorrow).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_tomorrow\");\n startValue = new Date(strTomorrow + \"T00:00:00Z\");\n endValue = new Date(strTomorrow + \"T23:59:59Z\");\n break;\n case \"last_7_days\":\n strStartDay = moment(last_7_days).format(\"YYYY-MM-DD\");\n strEndDay = moment(now).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_last_7_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n break;\n case \"last_30_days\":\n strStartDay = moment(last_30_days).format(\"YYYY-MM-DD\");\n strEndDay = moment(now).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_last_30_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n break;\n case \"last_60_days\":\n strStartDay = moment(last_60_days).format(\"YYYY-MM-DD\");\n strEndDay = moment(now).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_last_60_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n break;\n case \"last_90_days\":\n strStartDay = moment(last_90_days).format(\"YYYY-MM-DD\");\n strEndDay = moment(now).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_last_90_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n break;\n case \"last_120_days\":\n strStartDay = moment(last_120_days).format(\"YYYY-MM-DD\");\n strEndDay = moment(now).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_last_120_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n break;\n case \"next_7_days\":\n strStartDay = moment(now).format(\"YYYY-MM-DD\");\n strEndDay = moment(next_7_days).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_next_7_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n break;\n case \"next_30_days\":\n strStartDay = moment(now).format(\"YYYY-MM-DD\");\n strEndDay = moment(next_30_days).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_next_30_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n break;\n case \"next_60_days\":\n strStartDay = moment(now).format(\"YYYY-MM-DD\");\n strEndDay = moment(next_60_days).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_next_60_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n break;\n case \"next_90_days\":\n strStartDay = moment(now).format(\"YYYY-MM-DD\");\n strEndDay = moment(next_90_days).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_next_90_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n break;\n case \"next_120_days\":\n strStartDay = moment(now).format(\"YYYY-MM-DD\");\n strEndDay = moment(next_120_days).format(\"YYYY-MM-DD\");\n label = t(\"creator_filter_operation_between_next_120_days\");\n startValue = new Date(strStartDay + \"T00:00:00Z\");\n endValue = new Date(strEndDay + \"T23:59:59Z\");\n }\n values = [startValue, endValue];\n if (field_type === \"datetime\") {\n _.forEach(values, function(fv) {\n if (fv) {\n return fv.setHours(fv.getHours() + fv.getTimezoneOffset() / 60);\n }\n });\n }\n return {\n label: label,\n key: key,\n values: values\n };\n};\n\nCreator.getFieldDefaultOperation = function(field_type) {\n if (field_type && Creator.checkFieldTypeSupportBetweenQuery(field_type)) {\n return 'between';\n } else if ([\"textarea\", \"text\", \"code\"].includes(field_type)) {\n return 'contains';\n } else {\n return \"=\";\n }\n};\n\nCreator.getFieldOperation = function(field_type) {\n var operations, optionals;\n optionals = {\n equal: {\n label: t(\"creator_filter_operation_equal\"),\n value: \"=\"\n },\n unequal: {\n label: t(\"creator_filter_operation_unequal\"),\n value: \"<>\"\n },\n less_than: {\n label: t(\"creator_filter_operation_less_than\"),\n value: \"<\"\n },\n greater_than: {\n label: t(\"creator_filter_operation_greater_than\"),\n value: \">\"\n },\n less_or_equal: {\n label: t(\"creator_filter_operation_less_or_equal\"),\n value: \"<=\"\n },\n greater_or_equal: {\n label: t(\"creator_filter_operation_greater_or_equal\"),\n value: \">=\"\n },\n contains: {\n label: t(\"creator_filter_operation_contains\"),\n value: \"contains\"\n },\n not_contain: {\n label: t(\"creator_filter_operation_does_not_contain\"),\n value: \"notcontains\"\n },\n starts_with: {\n label: t(\"creator_filter_operation_starts_with\"),\n value: \"startswith\"\n },\n between: {\n label: t(\"creator_filter_operation_between\"),\n value: \"between\"\n }\n };\n if (field_type === void 0) {\n return _.values(optionals);\n }\n operations = [];\n if (Creator.checkFieldTypeSupportBetweenQuery(field_type)) {\n operations.push(optionals.between);\n Creator.pushBetweenBuiltinOptionals(field_type, operations);\n } else if (field_type === \"text\" || field_type === \"textarea\" || field_type === \"html\" || field_type === \"code\") {\n operations.push(optionals.contains);\n } else if (field_type === \"lookup\" || field_type === \"master_detail\" || field_type === \"select\") {\n operations.push(optionals.equal, optionals.unequal);\n } else if (field_type === \"currency\" || field_type === \"number\") {\n operations.push(optionals.equal, optionals.unequal, optionals.less_than, optionals.greater_than, optionals.less_or_equal, optionals.greater_or_equal);\n } else if (field_type === \"boolean\") {\n operations.push(optionals.equal, optionals.unequal);\n } else if (field_type === \"checkbox\") {\n operations.push(optionals.equal, optionals.unequal);\n } else if (field_type === \"[text]\") {\n operations.push(optionals.equal, optionals.unequal);\n } else {\n operations.push(optionals.equal, optionals.unequal);\n }\n return operations;\n};\n\n\n/*\n 先按照有排序号的小的在前,大的在后\n 再将没有排序号的显示在\n */\n\nCreator.getObjectFieldsName = function(object_name) {\n var fields, fieldsArr, fieldsName, ref;\n fields = (ref = Creator.getObject(object_name)) != null ? ref.fields : void 0;\n fieldsArr = [];\n _.each(fields, function(field) {\n return fieldsArr.push({\n name: field.name,\n sort_no: field.sort_no\n });\n });\n fieldsName = [];\n _.each(_.sortBy(fieldsArr, \"sort_no\"), function(field) {\n return fieldsName.push(field.name);\n });\n return fieldsName;\n};\n","Creator._trigger_hooks = {}\n\ninitTrigger = (object_name, trigger)->\n\ttry\n\t\tcollection = Creator.getCollection(object_name)\n\t\tif !trigger.todo\n\t\t\treturn\n\t\ttodoWrapper = ()->\n\t\t\t this.object_name = object_name\n\t\t\t return trigger.todo.apply(this, arguments)\n\t\tif trigger.when == \"before.insert\"\n\t\t\t return collection?.before?.insert(todoWrapper)\n\t\t else if trigger.when == \"before.update\"\n\t\t\t return collection?.before?.update(todoWrapper)\n\t\t else if trigger.when == \"before.remove\"\n\t\t\t return collection?.before?.remove(todoWrapper)\n\t\t else if trigger.when == \"after.insert\"\n\t\t\t return collection?.after?.insert(todoWrapper)\n\t\t else if trigger.when == \"after.update\"\n\t\t\t return collection?.after?.update(todoWrapper)\n\t\t else if trigger.when == \"after.remove\"\n\t\t\t return collection?.after?.remove(todoWrapper)\n\tcatch error\n\t\tconsole.error('initTrigger error', error)\n\ncleanTrigger = (object_name)->\n\t###\n \t由于collection-hooks package 的remove函数是使用下标删除对象的,所以此处反转hooks集合后,再删除\n \t因为一个数组元素删除后,其他元素的下标会发生变化\n\t###\n #TODO 由于collection-hooks package 的remove函数bug\n\tCreator._trigger_hooks[object_name]?.reverse().forEach (_hook)->\n\t\t_hook.remove()\n\nCreator.initTriggers = (object_name)->\n#\tconsole.log('Creator.initTriggers object_name', object_name)\n\tobj = Creator.getObject(object_name)\n\n\tcleanTrigger(object_name)\n\n\tCreator._trigger_hooks[object_name] = []\n\n\t_.each obj.triggers, (trigger, trigger_name)->\n\t\tif Meteor.isServer and trigger.on == \"server\" and trigger.todo and trigger.when\n\t\t\t_trigger_hook = initTrigger object_name, trigger\n\t\t\tif _trigger_hook\n\t\t\t\tCreator._trigger_hooks[object_name].push(_trigger_hook)\n\t\tif Meteor.isClient and trigger.on == \"client\" and trigger.todo and trigger.when\n\t\t\t_trigger_hook = initTrigger object_name, trigger\n\t\t\tCreator._trigger_hooks[object_name].push(_trigger_hook)","var cleanTrigger, initTrigger;\n\nCreator._trigger_hooks = {};\n\ninitTrigger = function(object_name, trigger) {\n var collection, error, ref, ref1, ref2, ref3, ref4, ref5, todoWrapper;\n try {\n collection = Creator.getCollection(object_name);\n if (!trigger.todo) {\n return;\n }\n todoWrapper = function() {\n this.object_name = object_name;\n return trigger.todo.apply(this, arguments);\n };\n if (trigger.when === \"before.insert\") {\n return collection != null ? (ref = collection.before) != null ? ref.insert(todoWrapper) : void 0 : void 0;\n } else if (trigger.when === \"before.update\") {\n return collection != null ? (ref1 = collection.before) != null ? ref1.update(todoWrapper) : void 0 : void 0;\n } else if (trigger.when === \"before.remove\") {\n return collection != null ? (ref2 = collection.before) != null ? ref2.remove(todoWrapper) : void 0 : void 0;\n } else if (trigger.when === \"after.insert\") {\n return collection != null ? (ref3 = collection.after) != null ? ref3.insert(todoWrapper) : void 0 : void 0;\n } else if (trigger.when === \"after.update\") {\n return collection != null ? (ref4 = collection.after) != null ? ref4.update(todoWrapper) : void 0 : void 0;\n } else if (trigger.when === \"after.remove\") {\n return collection != null ? (ref5 = collection.after) != null ? ref5.remove(todoWrapper) : void 0 : void 0;\n }\n } catch (error1) {\n error = error1;\n return console.error('initTrigger error', error);\n }\n};\n\ncleanTrigger = function(object_name) {\n\n /*\n \t由于collection-hooks package 的remove函数是使用下标删除对象的,所以此处反转hooks集合后,再删除\n \t因为一个数组元素删除后,其他元素的下标会发生变化\n */\n var ref;\n return (ref = Creator._trigger_hooks[object_name]) != null ? ref.reverse().forEach(function(_hook) {\n return _hook.remove();\n }) : void 0;\n};\n\nCreator.initTriggers = function(object_name) {\n var obj;\n obj = Creator.getObject(object_name);\n cleanTrigger(object_name);\n Creator._trigger_hooks[object_name] = [];\n return _.each(obj.triggers, function(trigger, trigger_name) {\n var _trigger_hook;\n if (Meteor.isServer && trigger.on === \"server\" && trigger.todo && trigger.when) {\n _trigger_hook = initTrigger(object_name, trigger);\n if (_trigger_hook) {\n Creator._trigger_hooks[object_name].push(_trigger_hook);\n }\n }\n if (Meteor.isClient && trigger.on === \"client\" && trigger.todo && trigger.when) {\n _trigger_hook = initTrigger(object_name, trigger);\n return Creator._trigger_hooks[object_name].push(_trigger_hook);\n }\n });\n};\n","clone = require('clone')\n\nbaseBooleanPermissionPropNames = [\"allowCreate\", \"allowDelete\", \"allowEdit\", \"allowRead\", \"modifyAllRecords\", \"viewAllRecords\", \"modifyCompanyRecords\", \"viewCompanyRecords\", \n\t\"allowReadFiles\", \"allowEditFiles\", \"allowCreateFiles\", \"allowDeleteFiles\", \"viewAllFiles\", \"modifyAllFiles\"] \notherPermissionPropNames = [\"disabled_list_views\", \"disabled_actions\", \"unreadable_fields\", \"uneditable_fields\", \"unrelated_objects\", \"uneditable_related_list\"]\npermissionPropNames = _.union baseBooleanPermissionPropNames, otherPermissionPropNames\n\nCreator.getPermissions = (object_name, spaceId, userId)->\n\tif Meteor.isClient\n\t\tif !object_name\n\t\t\tobject_name = Session.get(\"object_name\")\n\t\tobj = Creator.getObject(object_name)\n\t\tif !obj\n\t\t\treturn\n\t\treturn obj.permissions.get()\n\telse if Meteor.isServer\n\t\tCreator.getObjectPermissions(spaceId, userId, object_name)\n\nCreator.getRecordPermissions = (object_name, record, userId, spaceId)->\n\tif !object_name and Meteor.isClient\n\t\tobject_name = Session.get(\"object_name\")\n\n\tif !spaceId and Meteor.isClient\n\t\tspaceId = Session.get(\"spaceId\")\n\t\n\t# 附件权限不再与其父记录编辑配置关联\n\t# if record and object_name == \"cms_files\" and Meteor.isClient\n\t# \t# 如果是cms_files附件,则权限取其父记录权限\n\t# \tif object_name == Session.get('object_name')\n\t# \t\t# 当前处于cms_files附件详细界面\n\t# \t\tobject_name = record.parent['reference_to._o'];\n\t# \t\trecord_id = record.parent._id;\n\t# \telse \n\t# \t\t# 当前处于cms_files附件的父记录界面\n\t# \t\tobject_name = Session.get('object_name');\n\t# \t\trecord_id = Session.get(\"record_id\");\n\t# \tobject_fields_keys = _.keys(Creator.getObject(object_name, spaceId)?.fields or {}) || [];\n\t# \tselect = _.intersection(object_fields_keys, ['owner', 'company_id', 'company_ids', 'locked']) || [];\n\t# \tif select.length > 0\n\t# \t\trecord = Creator.getObjectRecord(object_name, record_id, select.join(','));\n\t# \telse\n\t# \t\trecord = null;\n\n\tpermissions = _.clone(Creator.getPermissions(object_name, spaceId, userId))\n\n\tif record\n\t\tif !_.isEmpty(record.record_permissions)\n\t\t\treturn record.record_permissions\n\n\t\tisOwner = record.owner == userId || record.owner?._id == userId\n\n\t\tif object_name == \"cms_files\"\n\t\t\t# 附件的查看所有修改所有权限与附件对象的viewAllRecords、modifyAllRecords无关,只与其主表记录的viewAllFiles和modifyAllFiles有关\n\t\t\t# 如果是cms_files附件,则权限需要额外考虑其父对象上关于附件的权限配置\n\t\t\tmasterObjectName = record.parent['reference_to._o'];\n\t\t\tmasterRecordPerm = Creator.getPermissions(masterObjectName, spaceId, userId)\n\t\t\tpermissions.allowCreate = permissions.allowCreate && masterRecordPerm.allowCreateFiles\n\t\t\tpermissions.allowEdit = permissions.allowEdit && masterRecordPerm.allowEditFiles\n\t\t\tpermissions.allowDelete = permissions.allowDelete && masterRecordPerm.allowDeleteFiles\n\t\t\tif !masterRecordPerm.modifyAllFiles and !isOwner\n\t\t\t\tpermissions.allowEdit = false\n\t\t\t\tpermissions.allowDelete = false\n\t\t\tpermissions.allowRead = permissions.allowRead && masterRecordPerm.allowReadFiles\n\t\t\tif !masterRecordPerm.viewAllFiles and !isOwner\n\t\t\t\tpermissions.allowRead = false\n\t\telse\n\t\t\tif Meteor.isClient\n\t\t\t\tuser_company_ids = Steedos.getUserCompanyIds()\n\t\t\telse\n\t\t\t\tuser_company_ids = Creator.getUserCompanyIds(userId, spaceId)\n\t\t\trecord_company_id = record?.company_id\n\t\t\tif record_company_id and _.isObject(record_company_id) and record_company_id._id\n\t\t\t\t# 因record_company_id是lookup类型,有可能dx控件会把它映射转为对应的object,所以这里取出其_id值\n\t\t\t\trecord_company_id = record_company_id._id\n\t\t\trecord_company_ids = record?.company_ids\n\t\t\tif record_company_ids and record_company_ids.length and _.isObject(record_company_ids[0])\n\t\t\t\t# 因record_company_ids是lookup类型,有可能dx控件会把它映射转为对应的[object],所以这里取出其_id值\n\t\t\t\trecord_company_ids = record_company_ids.map((n)-> n._id)\n\t\t\trecord_company_ids = _.union(record_company_ids, [record_company_id])\n\t\t\tif !permissions.modifyAllRecords and !isOwner and !permissions.modifyCompanyRecords\n\t\t\t\tpermissions.allowEdit = false\n\t\t\t\tpermissions.allowDelete = false\n\t\t\telse if !permissions.modifyAllRecords and permissions.modifyCompanyRecords\n\t\t\t\tif record_company_ids and record_company_ids.length\n\t\t\t\t\tif user_company_ids and user_company_ids.length\n\t\t\t\t\t\tif !_.intersection(user_company_ids, record_company_ids).length\n\t\t\t\t\t\t\t# 记录的company_id/company_ids属性不在当前用户user_company_ids范围内时,认为无权修改\n\t\t\t\t\t\t\tpermissions.allowEdit = false\n\t\t\t\t\t\t\tpermissions.allowDelete = false\n\t\t\t\t\telse\n\t\t\t\t\t\t# 记录有company_id/company_ids属性,但是当前用户user_company_ids为空时,认为无权修改\n\t\t\t\t\t\tpermissions.allowEdit = false\n\t\t\t\t\t\tpermissions.allowDelete = false\n\t\t\t\n\t\t\tif record.locked and !permissions.modifyAllRecords\n\t\t\t\tpermissions.allowEdit = false\n\t\t\t\tpermissions.allowDelete = false\n\n\t\t\tif !permissions.viewAllRecords and !isOwner and !permissions.viewCompanyRecords\n\t\t\t\tpermissions.allowRead = false\n\t\t\telse if !permissions.viewAllRecords and permissions.viewCompanyRecords\n\t\t\t\tif record_company_ids and record_company_ids.length\n\t\t\t\t\tif user_company_ids and user_company_ids.length\n\t\t\t\t\t\tif !_.intersection(user_company_ids, record_company_ids).length\n\t\t\t\t\t\t\t# 记录的company_id/company_ids属性不在当前用户user_company_ids范围内时,认为无权查看\n\t\t\t\t\t\t\tpermissions.allowRead = false\n\t\t\t\t\telse\n\t\t\t\t\t\t# 记录有company_id属性,但是当前用户user_company_ids为空时,认为无权查看\n\t\t\t\t\t\tpermissions.allowRead = false\n\t\n\treturn permissions\n\n\n# currentObjectName:当前主对象\n# relatedListItem:Creator.getRelatedList(Session.get(\"object_name\"), Session.get(\"record_id\"))中取related_object_name对应的值\n# currentRecord当前主对象的详细记录\nif Meteor.isClient\n\tCreator.getRecordRelatedListPermissions = (currentObjectName, relatedListItem, currentRecord, userId, spaceId)->\n\t\tif !currentObjectName and Meteor.isClient\n\t\t\tcurrentObjectName = Session.get(\"object_name\")\n\n\t\tif !relatedListItem\n\t\t\tconsole.error(\"relatedListItem must not be empty for the function Creator.getRecordRelatedListPermissions\");\n\t\t\treturn {}\n\n\t\tif !currentRecord and Meteor.isClient\n\t\t\tcurrentRecord = Creator.getObjectRecord()\n\n\t\tif !userId and Meteor.isClient\n\t\t\tuserId = Meteor.userId()\n\n\t\tif !spaceId and Meteor.isClient\n\t\t\tspaceId = Session.get(\"spaceId\")\n\n\t\tmasterRecordPerm = Creator.getRecordPermissions(currentObjectName, currentRecord, userId, spaceId)\n\t\trelatedObjectPermissions = Creator.getPermissions(relatedListItem.object_name)\n\t\tresult = _.clone relatedObjectPermissions\n\n\t\tif relatedListItem.is_file\n\t\t\tresult.allowCreate = relatedObjectPermissions.allowCreate && masterRecordPerm.allowCreateFiles\n\t\t\tresult.allowEdit = relatedObjectPermissions.allowEdit && masterRecordPerm.allowEditFiles\n\t\telse\n\t\t\twrite_requires_master_read = relatedListItem.write_requires_master_read || false\n\t\t\tmasterAllow = false\n\t\t\tif write_requires_master_read == true\n\t\t\t\tmasterAllow = masterRecordPerm.allowRead\n\t\t\telse if write_requires_master_read == false\n\t\t\t\tmasterAllow = masterRecordPerm.allowEdit\n\n\t\t\tuneditable_related_list = Creator.getRecordSafeRelatedList(currentRecord, currentObjectName)\n\t\t\tisRelateObjectUneditable = uneditable_related_list.indexOf(relatedListItem.object_name) > -1\n\n\t\t\tresult.allowCreate = masterAllow && relatedObjectPermissions.allowCreate && !isRelateObjectUneditable\n\t\t\tresult.allowEdit = masterAllow && relatedObjectPermissions.allowEdit && !isRelateObjectUneditable\n\t\treturn result\n\nif Meteor.isServer\n\n\tCreator.getAllPermissions = (spaceId, userId) ->\n\t\tpermissions =\n\t\t\tobjects: {}\n\t\t\tassigned_apps: []\n\t\t###\n\t\t权限集说明:\n\t\t内置权限集-admin,user,member,guest,workflow_admin,organization_admin\n\t\t自定义权限集-数据库中新建的除内置权限集以外的其他权限集\n\t\t特定用户集合权限集(即users属性不可配置)-admin,user,member,guest\n\t\t可配置用户集合权限集(即users属性可配置)-workflow_admin,organization_admin以及自定义权限集\n\t\t###\n\n\t\tisSpaceAdmin = false\n\t\tspaceUser = null\n\t\tif userId\n\t\t\tisSpaceAdmin = Creator.isSpaceAdmin(spaceId, userId)\n\t\t\tspaceUser = Creator.getCollection(\"space_users\").findOne({ space: spaceId, user: userId }, { fields: { profile: 1 } })\n\n\t\tpsetsAdmin = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'admin'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tpsetsUser = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'user'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tpsetsMember = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'member'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tpsetsGuest = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'guest'}, {fields:{_id:1, assigned_apps:1}}) || null\n\n\t\tpsetsSupplier = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'supplier'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tpsetsCustomer = Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'customer'}, {fields:{_id:1, assigned_apps:1}}) || null\n\t\tif spaceUser && spaceUser.profile\n\t\t\tpsetsCurrent = Creator.getCollection(\"permission_set\").find({space: spaceId, $or: [{users: userId}, {name: spaceUser.profile}]}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\telse\n\t\t\tpsetsCurrent = Creator.getCollection(\"permission_set\").find({users: userId, space: spaceId}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\n\t\tpsetsAdmin_pos = null\n\t\tpsetsUser_pos = null\n\t\tpsetsMember_pos = null\n\t\tpsetsGuest_pos = null\n\t\tpsetsCurrent_pos = null\n\t\tpsetsSupplier_pos = null\n\t\tpsetsCustomer_pos = null\n\n\t\tif psetsAdmin?._id\n\t\t\tpsetsAdmin_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsAdmin._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsUser?._id\n\t\t\tpsetsUser_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsUser._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsMember?._id\n\t\t\tpsetsMember_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsMember._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsGuest?._id\n\t\t\tpsetsGuest_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsGuest._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsSupplier?._id\n\t\t\tpsetsSupplier_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsSupplier._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\t\tif psetsCustomer?._id\n\t\t\tpsetsCustomer_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: psetsCustomer._id}, {fields: {created: 0, modified: 0, created_by: 0, modified_by: 0}}).fetch()\n\n\t\tif psetsCurrent.length > 0\n\t\t\tset_ids = _.pluck psetsCurrent, \"_id\"\n\t\t\tpsetsCurrent_pos = Creator.getCollection(\"permission_objects\").find({permission_set_id: {$in: set_ids}}).fetch()\n\t\t\tpsetsCurrentNames = _.pluck psetsCurrent, \"name\"\n\t\tpsets = {\n\t\t\tpsetsAdmin, \n\t\t\tpsetsUser, \n\t\t\tpsetsCurrent, \n\t\t\tpsetsMember, \n\t\t\tpsetsGuest,\n\t\t\tpsetsSupplier,\n\t\t\tpsetsCustomer,\n\t\t\tisSpaceAdmin,\n\t\t\tspaceUser, \n\t\t\tpsetsAdmin_pos, \n\t\t\tpsetsUser_pos, \n\t\t\tpsetsMember_pos, \n\t\t\tpsetsGuest_pos,\n\t\t\tpsetsSupplier_pos,\n\t\t\tpsetsCustomer_pos,\n\t\t\tpsetsCurrent_pos\n\t\t}\n\t\tpermissions.assigned_apps = Creator.getAssignedApps.bind(psets)(spaceId, userId)\n\t\tpermissions.assigned_menus = Creator.getAssignedMenus.bind(psets)(spaceId, userId)\n\t\tpermissions.user_permission_sets = psetsCurrentNames\n\t\t_i = 0\n\t\t_.each Creator.objectsByName, (object, object_name)->\n\t\t\t_i++\n\t\t\tif !_.has(object, 'space') || !object.space || object.space == spaceId\n\t\t\t\tif !_.has(object, 'in_development') || object.in_development == '0' || (object.in_development != '0' && isSpaceAdmin)\n\t\t\t\t\tpermissions.objects[object_name] = Creator.convertObject(clone(Creator.Objects[object_name]), spaceId)\n\t\t\t\t\tpermissions.objects[object_name][\"permissions\"] = Creator.getObjectPermissions.bind(psets)(spaceId, userId, object_name)\n\t\treturn permissions\n\n\tunionPlus = (array, other) ->\n\t\tif !array and !other\n\t\t\treturn undefined\n\t\tif !array\n\t\t\tarray = []\n\t\tif !other\n\t\t\tother = []\n\t\treturn _.union(array, other)\n\n\tintersectionPlus = (array, other) ->\n\t\tif !array and !other\n\t\t\treturn undefined\n\t\tif !array\n\t\t\tarray = []\n\t\tif !other\n\t\t\tother = []\n\t\treturn _.intersection(array, other)\n\n\textendPermissionProps = (target, props) ->\n\t\tpropNames = permissionPropNames\n\t\tfilesProNames = \n\t\tif props\n\t\t\t_.each propNames, (propName) ->\n\t\t\t\ttarget[propName] = props[propName]\n\n\t\t\t# target.allowCreate = props.allowCreate\n\t\t\t# target.allowDelete = props.allowDelete\n\t\t\t# target.allowEdit = props.allowEdit\n\t\t\t# target.allowRead = props.allowRead\n\t\t\t# target.modifyAllRecords = props.modifyAllRecords\n\t\t\t# target.viewAllRecords = props.viewAllRecords\n\t\t\t# target.modifyCompanyRecords = props.modifyCompanyRecords\n\t\t\t# target.viewCompanyRecords = props.viewCompanyRecords\n\t\t\t# target.disabled_list_views = props.disabled_list_views\n\t\t\t# target.disabled_actions = props.disabled_actions\n\t\t\t# target.unreadable_fields = props.unreadable_fields\n\t\t\t# target.uneditable_fields = props.uneditable_fields\n\t\t\t# target.unrelated_objects = props.unrelated_objects\n\t\t\t# target.uneditable_related_list = props.uneditable_related_list\n\n\toverlayBaseBooleanPermissionProps = (target, props) ->\n\t\tpropNames = baseBooleanPermissionPropNames\n\t\t_.each propNames, (propName) ->\n\t\t\tif props[propName]\n\t\t\t\ttarget[propName] = true\n\t\t\n\t\t# if po.allowRead\n\t\t# \tpermissions.allowRead = true\n\t\t# if po.allowCreate\n\t\t# \tpermissions.allowCreate = true\n\t\t# if po.allowEdit\n\t\t# \tpermissions.allowEdit = true\n\t\t# if po.allowDelete\n\t\t# \tpermissions.allowDelete = true\n\t\t# if po.modifyAllRecords\n\t\t# \tpermissions.modifyAllRecords = true\n\t\t# if po.viewAllRecords\n\t\t# \tpermissions.viewAllRecords = true\n\t\t# if po.modifyCompanyRecords\n\t\t# \tpermissions.modifyCompanyRecords = true\n\t\t# if po.viewCompanyRecords\n\t\t# \tpermissions.viewCompanyRecords = true\n\n\n\tCreator.getAssignedApps = (spaceId, userId)->\n\t\tpsetsAdmin = this.psetsAdmin || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'admin'}, {fields:{_id:1, assigned_apps:1}})\n\t\tpsetsUser = this.psetsUser || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'user'}, {fields:{_id:1, assigned_apps:1}})\n\t\tpsetsSupplier = this.psetsMember || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'supplier'}, {fields:{_id:1, assigned_apps:1}})\n\t\tpsetsCustomer = this.psetsGuest || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'customer'}, {fields:{_id:1, assigned_apps:1}})\n\t\t# psetsMember = this.psetsMember || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'member'}, {fields:{_id:1, assigned_apps:1}})\n\t\t# psetsGuest = this.psetsGuest || Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'guest'}, {fields:{_id:1, assigned_apps:1}})\n\t\tspaceUser = null;\n\t\tif userId\n\t\t\tspaceUser = Creator.getCollection(\"space_users\").findOne({ space: spaceId, user: userId }, { fields: { profile: 1 } })\n\t\tif spaceUser && spaceUser.profile\n\t\t\tpsets = Creator.getCollection(\"permission_set\").find({space: spaceId, $or: [{users: userId}, {name: spaceUser.profile}]}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\telse\n\t\t\tpsets = Creator.getCollection(\"permission_set\").find({users: userId, space: spaceId}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\tisSpaceAdmin = if _.isBoolean(this.isSpaceAdmin) then this.isSpaceAdmin else Creator.isSpaceAdmin(spaceId, userId)\n\t\tapps = []\n\t\tif isSpaceAdmin\n\t\t\treturn []\n\t\telse\n\t\t\tuserProfile = Creator.getCollection(\"space_users\").findOne({space: spaceId, user: userId}, {fields: {profile: 1}})?.profile\n\t\t\tpsetBase = psetsUser\n\t\t\tif userProfile\n\t\t\t\tif userProfile == 'supplier'\n\t\t\t\t\tpsetBase = psetsSupplier\n\t\t\t\telse if userProfile == 'customer'\n\t\t\t\t\tpsetBase = psetsCustomer\n\t\t\tif psetBase?.assigned_apps?.length\n\t\t\t\tapps = _.union apps, psetBase.assigned_apps\n\t\t\telse\n\t\t\t\t# user权限集中的assigned_apps表示所有用户具有的apps权限,为空则表示有所有apps权限,不需要作权限判断了\n\t\t\t\treturn []\n\t\t\t_.each psets, (pset)->\n\t\t\t\tif !pset.assigned_apps\n\t\t\t\t\treturn\n\t\t\t\tif pset.name == \"admin\" || pset.name == \"user\" || pset.name == 'supplier' || pset.name == 'customer'\n\t\t\t\t\t# 这里之所以要排除admin/user,是因为这两个权限集是所有权限集中users属性无效的权限集,特指工作区管理员和所有用户\n\t\t\t\t\treturn\n\t\t\t\tapps = _.union apps, pset.assigned_apps\n\t\t\treturn _.without(_.uniq(apps),undefined,null)\n\n\tCreator.getAssignedMenus = (spaceId, userId)->\n\t\tpsets = this.psetsCurrent || Creator.getCollection(\"permission_set\").find({users: userId, space: spaceId}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\tisSpaceAdmin = if _.isBoolean(this.isSpaceAdmin) then this.isSpaceAdmin else Creator.isSpaceAdmin(spaceId, userId)\n\t\tadminMenus = Creator.Apps.admin?.admin_menus\n\t\t# 如果没有admin菜单说明不需要相关功能,直接返回空\n\t\tunless adminMenus\n\t\t\treturn []\n\t\taboutMenu = adminMenus.find (n) ->\n\t\t\tn._id == 'about'\n\t\tadminMenus = adminMenus.filter (n) ->\n\t\t\tn._id != 'about'\n\t\totherMenuApps = _.sortBy _.filter(_.values(Creator.Apps), (n) ->\n\t\t\treturn n.admin_menus and n._id != 'admin'\n\t\t), 'sort'\n\t\totherMenus = _.flatten(_.pluck(otherMenuApps, \"admin_menus\"))\n\t\t# 菜单有三部分组成,设置APP菜单、其他APP菜单以及about菜单\n\t\tallMenus = _.union(adminMenus, otherMenus, [aboutMenu])\n\t\tif isSpaceAdmin\n\t\t\t# 工作区管理员有全部菜单功能\n\t\t\tresult = allMenus\n\t\telse\n\t\t\tuserProfile = Creator.getCollection(\"space_users\").findOne({space: spaceId, user: userId}, {fields: {profile: 1}})?.profile || 'user'\n\t\t\tcurrentPsetNames = psets.map (n) ->\n\t\t\t\treturn n.name\n\t\t\tmenus = allMenus.filter (menu)->\n\t\t\t\tpsetsMenu = menu.permission_sets\n\t\t\t\t# 如果普通用户有权限,则直接返回true\n\t\t\t\tif psetsMenu && psetsMenu.indexOf(userProfile) > -1\n\t\t\t\t\treturn true\n\t\t\t\t# 否则取当前用户的权限集与menu菜单要求的权限集对比,如果交集大于1个则返回true\n\t\t\t\treturn _.intersection(currentPsetNames, psetsMenu).length\n\t\t\tresult = menus\n\t\t\n\t\treturn _.sortBy(result,\"sort\")\n\n\tfindOne_permission_object = (permission_objects, object_name, permission_set_id)->\n\n\t\tif _.isNull(permission_objects)\n\t\t\treturn null\n\t\tif _.isArray(permission_objects)\n\t\t\treturn _.find permission_objects, (po)->\n\t\t\t\t\treturn po.object_name == object_name\n\t\treturn Creator.getCollection(\"permission_objects\").findOne({object_name: object_name, permission_set_id: permission_set_id})\n\n\tfind_permission_object = (permission_objects, object_name, permission_set_ids)->\n\t\tif _.isNull(permission_objects)\n\t\t\treturn null\n\t\tif _.isArray(permission_objects)\n\t\t\treturn _.filter permission_objects, (po)->\n\t\t\t\treturn po.object_name == object_name\n\t\tCreator.getCollection(\"permission_objects\").find({object_name: object_name, permission_set_id: {$in: permission_set_ids}}).fetch()\n\n\tunionPermissionObjects = (pos, object, psets)->\n\t\t# 把db及yml中的permission_objects合并,优先取db中的\n\t\tresult = []\n\t\t_.each object.permission_set, (ops, ops_key)->\n\t\t\t# 把yml中除了特定用户集合权限集\"admin\", \"user\", \"member\", \"guest\"外的其他对象权限先存入result\n\t\t\t# if [\"admin\", \"user\", \"member\", \"guest\", \"workflow_admin\", \"organization_admin\"].indexOf(ops_key) < 0\n\t\t\tif [\"admin\", \"user\", \"member\", \"guest\"].indexOf(ops_key) < 0\n\t\t\t\tcurrentPset = psets.find (pset)-> return pset.name == ops_key\n\t\t\t\tif currentPset\n\t\t\t\t\ttempOps = _.clone(ops) || {}\n\t\t\t\t\ttempOps.permission_set_id = currentPset._id\n\t\t\t\t\ttempOps.object_name = object.object_name\n\t\t\t\t\tresult.push tempOps\n\t\tif result.length\n\t\t\tpos.forEach (po)->\n\t\t\t\trepeatIndex = 0\n\t\t\t\trepeatPo = result.find((item, index)-> repeatIndex = index;return item.permission_set_id == po.permission_set_id)\n\t\t\t\t# 如果yml中已经存在po,则替换为数据库中的po,反之则把数据库中的po直接累加进去\n\t\t\t\tif repeatPo\n\t\t\t\t\tresult[repeatIndex] = po\n\t\t\t\telse\n\t\t\t\t\tresult.push po\n\t\t\treturn result\n\t\telse\n\t\t\treturn pos\n\n\tCreator.getObjectPermissions = (spaceId, userId, object_name)->\n\t\tpermissions = {}\n\t\tobject = Creator.getObject(object_name, spaceId)\n\n\t\tif spaceId is 'guest' || object_name == \"users\"\n\t\t\tpermissions = _.clone(object.permission_set.guest) || {}\n\t\t\tCreator.processPermissions permissions\n\t\t\treturn permissions\n\t\tpsetsAdmin = if _.isNull(this.psetsAdmin) or this.psetsAdmin then this.psetsAdmin else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'admin'}, {fields:{_id:1}})\n\t\tpsetsUser = if _.isNull(this.psetsUser) or this.psetsUser then this.psetsUser else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'user'}, {fields:{_id:1}})\n\t\tpsetsMember = if _.isNull(this.psetsMember) or this.psetsMember then this.psetsMember else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'member'}, {fields:{_id:1}})\n\t\tpsetsGuest = if _.isNull(this.psetsGuest) or this.psetsGuest then this.psetsGuest else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'guest'}, {fields:{_id:1}})\n\n\t\tpsetsSupplier = if _.isNull(this.psetsSupplier) or this.psetsSupplier then this.psetsSupplier else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'supplier'}, {fields:{_id:1}})\n\t\tpsetsCustomer = if _.isNull(this.psetsCustomer) or this.psetsCustomer then this.psetsCustomer else Creator.getCollection(\"permission_set\").findOne({space: spaceId, name: 'customer'}, {fields:{_id:1}})\n\t\tpsets = this.psetsCurrent;\n\t\tif !psets\n\t\t\tspaceUser = null;\n\t\t\tif userId\n\t\t\t\tspaceUser = Creator.getCollection(\"space_users\").findOne({ space: spaceId, user: userId }, { fields: { profile: 1 } })\n\t\t\tif spaceUser && spaceUser.profile\n\t\t\t\tpsets = Creator.getCollection(\"permission_set\").find({space: spaceId, $or: [{users: userId}, {name: spaceUser.profile}]}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\t\telse\n\t\t\t\tpsets = Creator.getCollection(\"permission_set\").find({users: userId, space: spaceId}, {fields:{_id:1, assigned_apps:1, name:1}}).fetch()\n\t\tisSpaceAdmin = if _.isBoolean(this.isSpaceAdmin) then this.isSpaceAdmin else Creator.isSpaceAdmin(spaceId, userId)\n\n\t\tpsetsAdmin_pos = this.psetsAdmin_pos\n\t\tpsetsUser_pos = this.psetsUser_pos\n\t\tpsetsMember_pos = this.psetsMember_pos\n\t\tpsetsGuest_pos = this.psetsGuest_pos\n\n\t\tpsetsSupplier_pos = this.psetsSupplier_pos\n\t\tpsetsCustomer_pos = this.psetsCustomer_pos\n\n\t\tpsetsCurrent_pos = this.psetsCurrent_pos\n\n\t\topsetAdmin = _.clone(object.permission_set.admin) || {}\n\t\topsetUser = _.clone(object.permission_set.user) || {}\n\t\topsetMember = _.clone(object.permission_set.member) || {}\n\t\topsetGuest = _.clone(object.permission_set.guest) || {}\n\n\t\topsetSupplier = _.clone(object.permission_set.supplier) || {}\n\t\topsetCustomer = _.clone(object.permission_set.customer) || {}\n\n\t\t# sharedListViews = Creator.getCollection('object_listviews').find({space: spaceId, object_name: object_name, shared: true}, {fields:{_id:1}}).fetch()\n\t\t# sharedListViews = _.pluck(sharedListViews,\"_id\")\n\t\t# if sharedListViews.length\n\t\t# \tunless opsetAdmin.list_views\n\t\t# \t\topsetAdmin.list_views = []\n\t\t# \topsetAdmin.list_views = _.union opsetAdmin.list_views, sharedListViews\n\t\t# \tunless opsetUser.list_views\n\t\t# \t\topsetUser.list_views = []\n\t\t# \topsetUser.list_views = _.union opsetUser.list_views, sharedListViews\n\t\t# 数据库中如果配置了默认的admin/user权限集设置,应该覆盖代码中admin/user的权限集设置\n\t\tif psetsAdmin\n\t\t\tposAdmin = findOne_permission_object(psetsAdmin_pos, object_name, psetsAdmin._id)\n\t\t\textendPermissionProps opsetAdmin, posAdmin\n\t\tif psetsUser\n\t\t\tposUser = findOne_permission_object(psetsUser_pos, object_name, psetsUser._id)\n\t\t\textendPermissionProps opsetUser, posUser\n\t\tif psetsMember\n\t\t\tposMember = findOne_permission_object(psetsMember_pos, object_name, psetsMember._id)\n\t\t\textendPermissionProps opsetMember, posMember\n\t\tif psetsGuest\n\t\t\tposGuest = findOne_permission_object(psetsGuest_pos, object_name, psetsGuest._id)\n\t\t\textendPermissionProps opsetGuest, posGuest\n\t\tif psetsSupplier\n\t\t\tposSupplier = findOne_permission_object(psetsSupplier_pos, object_name, psetsSupplier._id);\n\t\t\textendPermissionProps opsetSupplier, posSupplier\n\t\tif psetsCustomer\n\t\t\tposCustomer = findOne_permission_object(psetsCustomer_pos, object_name, psetsCustomer._id);\n\t\t\textendPermissionProps opsetCustomer, posCustomer\n\n\t\tif !userId\n\t\t\tpermissions = opsetAdmin\n\t\telse\n\t\t\tif isSpaceAdmin\n\t\t\t\tpermissions = opsetAdmin\n\t\t\telse\n\t\t\t\tif spaceId is 'common'\n\t\t\t\t\tpermissions = opsetUser\n\t\t\t\telse\n\t\t\t\t\tspaceUser = if _.isNull(this.spaceUser) or this.spaceUser then this.spaceUser else Creator.getCollection(\"space_users\").findOne({ space: spaceId, user: userId }, { fields: { profile: 1 } })\n\t\t\t\t\tif spaceUser\n\t\t\t\t\t\tprof = spaceUser.profile\n\t\t\t\t\t\tif prof\n\t\t\t\t\t\t\tif prof is 'user'\n\t\t\t\t\t\t\t\tpermissions = opsetUser\n\t\t\t\t\t\t\telse if prof is 'member'\n\t\t\t\t\t\t\t\tpermissions = opsetMember\n\t\t\t\t\t\t\telse if prof is 'guest'\n\t\t\t\t\t\t\t\tpermissions = opsetGuest\n\t\t\t\t\t\t\telse if prof is 'supplier'\n\t\t\t\t\t\t\t\tpermissions = opsetSupplier\n\t\t\t\t\t\t\telse if prof is 'customer'\n\t\t\t\t\t\t\t\tpermissions = opsetCustomer\n\t\t\t\t\t\telse # 没有profile则认为是user权限\n\t\t\t\t\t\t\tpermissions = opsetUser\n\t\t\t\t\telse\n\t\t\t\t\t\tpermissions = opsetGuest\n\t\tif psets.length > 0\n\t\t\tset_ids = _.pluck psets, \"_id\"\n\t\t\tpos = find_permission_object(psetsCurrent_pos, object_name, set_ids)\n\t\t\tpos = unionPermissionObjects(pos, object, psets)\n\t\t\t_.each pos, (po)->\n\t\t\t\tif po.permission_set_id == psetsAdmin?._id or \n\t\t\t\tpo.permission_set_id == psetsUser?._id or \n\t\t\t\tpo.permission_set_id == psetsMember?._id or \n\t\t\t\tpo.permission_set_id == psetsGuest?._id or\n\t\t\t\tpo.permission_set_id == psetsSupplier?._id or\n\t\t\t\tpo.permission_set_id == psetsCustomer?._id\n\t\t\t\t\t# 默认的admin/user权限值只实行上面的默认值覆盖,不做算法判断\n\t\t\t\t\treturn\n\t\t\t\tif _.isEmpty(permissions)\n\t\t\t\t\tpermissions = po\n\t\t\t\toverlayBaseBooleanPermissionProps permissions, po\n\n\t\t\t\tpermissions.disabled_list_views = intersectionPlus(permissions.disabled_list_views, po.disabled_list_views)\n\t\t\t\tpermissions.disabled_actions = intersectionPlus(permissions.disabled_actions, po.disabled_actions)\n\t\t\t\tpermissions.unreadable_fields = intersectionPlus(permissions.unreadable_fields, po.unreadable_fields)\n\t\t\t\tpermissions.uneditable_fields = intersectionPlus(permissions.uneditable_fields, po.uneditable_fields)\n\t\t\t\tpermissions.unrelated_objects = intersectionPlus(permissions.unrelated_objects, po.unrelated_objects)\n\t\t\t\tpermissions.uneditable_related_list = intersectionPlus(permissions.uneditable_related_list, po.uneditable_related_list)\n\t\t\n\t\tif object.is_view\n\t\t\tpermissions.allowCreate = false\n\t\t\tpermissions.allowEdit = false\n\t\t\tpermissions.allowDelete = false\n\t\t\tpermissions.modifyAllRecords = false\n\t\t\tpermissions.modifyCompanyRecords = false\n\t\t\tpermissions.disabled_actions = []\n\t\tCreator.processPermissions permissions\n\n\t\tif object.permission_set.owner\n\t\t\tpermissions.owner = object.permission_set.owner\n\t\treturn permissions\n\n\n\t# Creator.initPermissions = (object_name) ->\n\n\t\t# # 应该把计算出来的\n\t\t# Creator.Collections[object_name].allow\n\t\t# \tinsert: (userId, doc) ->\n\t\t# \t\tif !userId\n\t\t# \t\t\treturn false\n\t\t# \t\tif !doc.space\n\t\t# \t\t\treturn false\n\t \t# \t\tpermissions = Creator.getObjectPermissions(doc.space, userId, object_name)\n\t\t# \t\tif !permissions.allowCreate\n\t\t# \t\t\treturn false\n\n\t\t# \t\treturn true\n\t\t# \tupdate: (userId, doc) ->\n\t\t# \t\tif !userId\n\t\t# \t\t\treturn false\n\t\t# \t\tif !doc.space\n\t\t# \t\t\treturn false\n\t\t# \t\tpermissions = Creator.getObjectPermissions(doc.space, userId, object_name)\n\t\t# \t\tif !permissions.allowEdit\n\t\t# \t\t\treturn false\n\t\t# \t\treturn true\n\t\t# \tremove: (userId, doc) ->\n\t\t# \t\tif !userId\n\t\t# \t\t\treturn false\n\t\t# \t\tif !doc.space\n\t\t# \t\t\treturn false\n\t\t# \t\tpermissions = Creator.getObjectPermissions(doc.space, userId, object_name)\n\t\t# \t\tif !permissions.allowDelete\n\t\t# \t\t\treturn false\n\t\t# \t\treturn true\n\n\tMeteor.methods\n\t\t# Calculate Permissions on Server\n\t\t\"creator.object_permissions\": (spaceId)->\n\t\t\treturn Creator.getAllPermissions(spaceId, this.userId)\n","var baseBooleanPermissionPropNames, clone, extendPermissionProps, findOne_permission_object, find_permission_object, intersectionPlus, otherPermissionPropNames, overlayBaseBooleanPermissionProps, permissionPropNames, unionPermissionObjects, unionPlus;\n\nclone = require('clone');\n\nbaseBooleanPermissionPropNames = [\"allowCreate\", \"allowDelete\", \"allowEdit\", \"allowRead\", \"modifyAllRecords\", \"viewAllRecords\", \"modifyCompanyRecords\", \"viewCompanyRecords\", \"allowReadFiles\", \"allowEditFiles\", \"allowCreateFiles\", \"allowDeleteFiles\", \"viewAllFiles\", \"modifyAllFiles\"];\n\notherPermissionPropNames = [\"disabled_list_views\", \"disabled_actions\", \"unreadable_fields\", \"uneditable_fields\", \"unrelated_objects\", \"uneditable_related_list\"];\n\npermissionPropNames = _.union(baseBooleanPermissionPropNames, otherPermissionPropNames);\n\nCreator.getPermissions = function(object_name, spaceId, userId) {\n var obj;\n if (Meteor.isClient) {\n if (!object_name) {\n object_name = Session.get(\"object_name\");\n }\n obj = Creator.getObject(object_name);\n if (!obj) {\n return;\n }\n return obj.permissions.get();\n } else if (Meteor.isServer) {\n return Creator.getObjectPermissions(spaceId, userId, object_name);\n }\n};\n\nCreator.getRecordPermissions = function(object_name, record, userId, spaceId) {\n var isOwner, masterObjectName, masterRecordPerm, permissions, record_company_id, record_company_ids, ref, user_company_ids;\n if (!object_name && Meteor.isClient) {\n object_name = Session.get(\"object_name\");\n }\n if (!spaceId && Meteor.isClient) {\n spaceId = Session.get(\"spaceId\");\n }\n permissions = _.clone(Creator.getPermissions(object_name, spaceId, userId));\n if (record) {\n if (!_.isEmpty(record.record_permissions)) {\n return record.record_permissions;\n }\n isOwner = record.owner === userId || ((ref = record.owner) != null ? ref._id : void 0) === userId;\n if (object_name === \"cms_files\") {\n masterObjectName = record.parent['reference_to._o'];\n masterRecordPerm = Creator.getPermissions(masterObjectName, spaceId, userId);\n permissions.allowCreate = permissions.allowCreate && masterRecordPerm.allowCreateFiles;\n permissions.allowEdit = permissions.allowEdit && masterRecordPerm.allowEditFiles;\n permissions.allowDelete = permissions.allowDelete && masterRecordPerm.allowDeleteFiles;\n if (!masterRecordPerm.modifyAllFiles && !isOwner) {\n permissions.allowEdit = false;\n permissions.allowDelete = false;\n }\n permissions.allowRead = permissions.allowRead && masterRecordPerm.allowReadFiles;\n if (!masterRecordPerm.viewAllFiles && !isOwner) {\n permissions.allowRead = false;\n }\n } else {\n if (Meteor.isClient) {\n user_company_ids = Steedos.getUserCompanyIds();\n } else {\n user_company_ids = Creator.getUserCompanyIds(userId, spaceId);\n }\n record_company_id = record != null ? record.company_id : void 0;\n if (record_company_id && _.isObject(record_company_id) && record_company_id._id) {\n record_company_id = record_company_id._id;\n }\n record_company_ids = record != null ? record.company_ids : void 0;\n if (record_company_ids && record_company_ids.length && _.isObject(record_company_ids[0])) {\n record_company_ids = record_company_ids.map(function(n) {\n return n._id;\n });\n }\n record_company_ids = _.union(record_company_ids, [record_company_id]);\n if (!permissions.modifyAllRecords && !isOwner && !permissions.modifyCompanyRecords) {\n permissions.allowEdit = false;\n permissions.allowDelete = false;\n } else if (!permissions.modifyAllRecords && permissions.modifyCompanyRecords) {\n if (record_company_ids && record_company_ids.length) {\n if (user_company_ids && user_company_ids.length) {\n if (!_.intersection(user_company_ids, record_company_ids).length) {\n permissions.allowEdit = false;\n permissions.allowDelete = false;\n }\n } else {\n permissions.allowEdit = false;\n permissions.allowDelete = false;\n }\n }\n }\n if (record.locked && !permissions.modifyAllRecords) {\n permissions.allowEdit = false;\n permissions.allowDelete = false;\n }\n if (!permissions.viewAllRecords && !isOwner && !permissions.viewCompanyRecords) {\n permissions.allowRead = false;\n } else if (!permissions.viewAllRecords && permissions.viewCompanyRecords) {\n if (record_company_ids && record_company_ids.length) {\n if (user_company_ids && user_company_ids.length) {\n if (!_.intersection(user_company_ids, record_company_ids).length) {\n permissions.allowRead = false;\n }\n } else {\n permissions.allowRead = false;\n }\n }\n }\n }\n }\n return permissions;\n};\n\nif (Meteor.isClient) {\n Creator.getRecordRelatedListPermissions = function(currentObjectName, relatedListItem, currentRecord, userId, spaceId) {\n var isRelateObjectUneditable, masterAllow, masterRecordPerm, relatedObjectPermissions, result, uneditable_related_list, write_requires_master_read;\n if (!currentObjectName && Meteor.isClient) {\n currentObjectName = Session.get(\"object_name\");\n }\n if (!relatedListItem) {\n console.error(\"relatedListItem must not be empty for the function Creator.getRecordRelatedListPermissions\");\n return {};\n }\n if (!currentRecord && Meteor.isClient) {\n currentRecord = Creator.getObjectRecord();\n }\n if (!userId && Meteor.isClient) {\n userId = Meteor.userId();\n }\n if (!spaceId && Meteor.isClient) {\n spaceId = Session.get(\"spaceId\");\n }\n masterRecordPerm = Creator.getRecordPermissions(currentObjectName, currentRecord, userId, spaceId);\n relatedObjectPermissions = Creator.getPermissions(relatedListItem.object_name);\n result = _.clone(relatedObjectPermissions);\n if (relatedListItem.is_file) {\n result.allowCreate = relatedObjectPermissions.allowCreate && masterRecordPerm.allowCreateFiles;\n result.allowEdit = relatedObjectPermissions.allowEdit && masterRecordPerm.allowEditFiles;\n } else {\n write_requires_master_read = relatedListItem.write_requires_master_read || false;\n masterAllow = false;\n if (write_requires_master_read === true) {\n masterAllow = masterRecordPerm.allowRead;\n } else if (write_requires_master_read === false) {\n masterAllow = masterRecordPerm.allowEdit;\n }\n uneditable_related_list = Creator.getRecordSafeRelatedList(currentRecord, currentObjectName);\n isRelateObjectUneditable = uneditable_related_list.indexOf(relatedListItem.object_name) > -1;\n result.allowCreate = masterAllow && relatedObjectPermissions.allowCreate && !isRelateObjectUneditable;\n result.allowEdit = masterAllow && relatedObjectPermissions.allowEdit && !isRelateObjectUneditable;\n }\n return result;\n };\n}\n\nif (Meteor.isServer) {\n Creator.getAllPermissions = function(spaceId, userId) {\n var _i, isSpaceAdmin, permissions, psets, psetsAdmin, psetsAdmin_pos, psetsCurrent, psetsCurrentNames, psetsCurrent_pos, psetsCustomer, psetsCustomer_pos, psetsGuest, psetsGuest_pos, psetsMember, psetsMember_pos, psetsSupplier, psetsSupplier_pos, psetsUser, psetsUser_pos, set_ids, spaceUser;\n permissions = {\n objects: {},\n assigned_apps: []\n };\n\n /*\n \t\t权限集说明:\n \t\t内置权限集-admin,user,member,guest,workflow_admin,organization_admin\n \t\t自定义权限集-数据库中新建的除内置权限集以外的其他权限集\n \t\t特定用户集合权限集(即users属性不可配置)-admin,user,member,guest\n \t\t可配置用户集合权限集(即users属性可配置)-workflow_admin,organization_admin以及自定义权限集\n */\n isSpaceAdmin = false;\n spaceUser = null;\n if (userId) {\n isSpaceAdmin = Creator.isSpaceAdmin(spaceId, userId);\n spaceUser = Creator.getCollection(\"space_users\").findOne({\n space: spaceId,\n user: userId\n }, {\n fields: {\n profile: 1\n }\n });\n }\n psetsAdmin = Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'admin'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n }) || null;\n psetsUser = Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'user'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n }) || null;\n psetsMember = Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'member'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n }) || null;\n psetsGuest = Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'guest'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n }) || null;\n psetsSupplier = Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'supplier'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n }) || null;\n psetsCustomer = Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'customer'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n }) || null;\n if (spaceUser && spaceUser.profile) {\n psetsCurrent = Creator.getCollection(\"permission_set\").find({\n space: spaceId,\n $or: [\n {\n users: userId\n }, {\n name: spaceUser.profile\n }\n ]\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1,\n name: 1\n }\n }).fetch();\n } else {\n psetsCurrent = Creator.getCollection(\"permission_set\").find({\n users: userId,\n space: spaceId\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1,\n name: 1\n }\n }).fetch();\n }\n psetsAdmin_pos = null;\n psetsUser_pos = null;\n psetsMember_pos = null;\n psetsGuest_pos = null;\n psetsCurrent_pos = null;\n psetsSupplier_pos = null;\n psetsCustomer_pos = null;\n if (psetsAdmin != null ? psetsAdmin._id : void 0) {\n psetsAdmin_pos = Creator.getCollection(\"permission_objects\").find({\n permission_set_id: psetsAdmin._id\n }, {\n fields: {\n created: 0,\n modified: 0,\n created_by: 0,\n modified_by: 0\n }\n }).fetch();\n }\n if (psetsUser != null ? psetsUser._id : void 0) {\n psetsUser_pos = Creator.getCollection(\"permission_objects\").find({\n permission_set_id: psetsUser._id\n }, {\n fields: {\n created: 0,\n modified: 0,\n created_by: 0,\n modified_by: 0\n }\n }).fetch();\n }\n if (psetsMember != null ? psetsMember._id : void 0) {\n psetsMember_pos = Creator.getCollection(\"permission_objects\").find({\n permission_set_id: psetsMember._id\n }, {\n fields: {\n created: 0,\n modified: 0,\n created_by: 0,\n modified_by: 0\n }\n }).fetch();\n }\n if (psetsGuest != null ? psetsGuest._id : void 0) {\n psetsGuest_pos = Creator.getCollection(\"permission_objects\").find({\n permission_set_id: psetsGuest._id\n }, {\n fields: {\n created: 0,\n modified: 0,\n created_by: 0,\n modified_by: 0\n }\n }).fetch();\n }\n if (psetsSupplier != null ? psetsSupplier._id : void 0) {\n psetsSupplier_pos = Creator.getCollection(\"permission_objects\").find({\n permission_set_id: psetsSupplier._id\n }, {\n fields: {\n created: 0,\n modified: 0,\n created_by: 0,\n modified_by: 0\n }\n }).fetch();\n }\n if (psetsCustomer != null ? psetsCustomer._id : void 0) {\n psetsCustomer_pos = Creator.getCollection(\"permission_objects\").find({\n permission_set_id: psetsCustomer._id\n }, {\n fields: {\n created: 0,\n modified: 0,\n created_by: 0,\n modified_by: 0\n }\n }).fetch();\n }\n if (psetsCurrent.length > 0) {\n set_ids = _.pluck(psetsCurrent, \"_id\");\n psetsCurrent_pos = Creator.getCollection(\"permission_objects\").find({\n permission_set_id: {\n $in: set_ids\n }\n }).fetch();\n psetsCurrentNames = _.pluck(psetsCurrent, \"name\");\n }\n psets = {\n psetsAdmin: psetsAdmin,\n psetsUser: psetsUser,\n psetsCurrent: psetsCurrent,\n psetsMember: psetsMember,\n psetsGuest: psetsGuest,\n psetsSupplier: psetsSupplier,\n psetsCustomer: psetsCustomer,\n isSpaceAdmin: isSpaceAdmin,\n spaceUser: spaceUser,\n psetsAdmin_pos: psetsAdmin_pos,\n psetsUser_pos: psetsUser_pos,\n psetsMember_pos: psetsMember_pos,\n psetsGuest_pos: psetsGuest_pos,\n psetsSupplier_pos: psetsSupplier_pos,\n psetsCustomer_pos: psetsCustomer_pos,\n psetsCurrent_pos: psetsCurrent_pos\n };\n permissions.assigned_apps = Creator.getAssignedApps.bind(psets)(spaceId, userId);\n permissions.assigned_menus = Creator.getAssignedMenus.bind(psets)(spaceId, userId);\n permissions.user_permission_sets = psetsCurrentNames;\n _i = 0;\n _.each(Creator.objectsByName, function(object, object_name) {\n _i++;\n if (!_.has(object, 'space') || !object.space || object.space === spaceId) {\n if (!_.has(object, 'in_development') || object.in_development === '0' || (object.in_development !== '0' && isSpaceAdmin)) {\n permissions.objects[object_name] = Creator.convertObject(clone(Creator.Objects[object_name]), spaceId);\n return permissions.objects[object_name][\"permissions\"] = Creator.getObjectPermissions.bind(psets)(spaceId, userId, object_name);\n }\n }\n });\n return permissions;\n };\n unionPlus = function(array, other) {\n if (!array && !other) {\n return void 0;\n }\n if (!array) {\n array = [];\n }\n if (!other) {\n other = [];\n }\n return _.union(array, other);\n };\n intersectionPlus = function(array, other) {\n if (!array && !other) {\n return void 0;\n }\n if (!array) {\n array = [];\n }\n if (!other) {\n other = [];\n }\n return _.intersection(array, other);\n };\n extendPermissionProps = function(target, props) {\n var filesProNames, propNames;\n propNames = permissionPropNames;\n return filesProNames = props ? _.each(propNames, function(propName) {\n return target[propName] = props[propName];\n }) : void 0;\n };\n overlayBaseBooleanPermissionProps = function(target, props) {\n var propNames;\n propNames = baseBooleanPermissionPropNames;\n return _.each(propNames, function(propName) {\n if (props[propName]) {\n return target[propName] = true;\n }\n });\n };\n Creator.getAssignedApps = function(spaceId, userId) {\n var apps, isSpaceAdmin, psetBase, psets, psetsAdmin, psetsCustomer, psetsSupplier, psetsUser, ref, ref1, spaceUser, userProfile;\n psetsAdmin = this.psetsAdmin || Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'admin'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n });\n psetsUser = this.psetsUser || Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'user'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n });\n psetsSupplier = this.psetsMember || Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'supplier'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n });\n psetsCustomer = this.psetsGuest || Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'customer'\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1\n }\n });\n spaceUser = null;\n if (userId) {\n spaceUser = Creator.getCollection(\"space_users\").findOne({\n space: spaceId,\n user: userId\n }, {\n fields: {\n profile: 1\n }\n });\n }\n if (spaceUser && spaceUser.profile) {\n psets = Creator.getCollection(\"permission_set\").find({\n space: spaceId,\n $or: [\n {\n users: userId\n }, {\n name: spaceUser.profile\n }\n ]\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1,\n name: 1\n }\n }).fetch();\n } else {\n psets = Creator.getCollection(\"permission_set\").find({\n users: userId,\n space: spaceId\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1,\n name: 1\n }\n }).fetch();\n }\n isSpaceAdmin = _.isBoolean(this.isSpaceAdmin) ? this.isSpaceAdmin : Creator.isSpaceAdmin(spaceId, userId);\n apps = [];\n if (isSpaceAdmin) {\n return [];\n } else {\n userProfile = (ref = Creator.getCollection(\"space_users\").findOne({\n space: spaceId,\n user: userId\n }, {\n fields: {\n profile: 1\n }\n })) != null ? ref.profile : void 0;\n psetBase = psetsUser;\n if (userProfile) {\n if (userProfile === 'supplier') {\n psetBase = psetsSupplier;\n } else if (userProfile === 'customer') {\n psetBase = psetsCustomer;\n }\n }\n if (psetBase != null ? (ref1 = psetBase.assigned_apps) != null ? ref1.length : void 0 : void 0) {\n apps = _.union(apps, psetBase.assigned_apps);\n } else {\n return [];\n }\n _.each(psets, function(pset) {\n if (!pset.assigned_apps) {\n return;\n }\n if (pset.name === \"admin\" || pset.name === \"user\" || pset.name === 'supplier' || pset.name === 'customer') {\n return;\n }\n return apps = _.union(apps, pset.assigned_apps);\n });\n return _.without(_.uniq(apps), void 0, null);\n }\n };\n Creator.getAssignedMenus = function(spaceId, userId) {\n var aboutMenu, adminMenus, allMenus, currentPsetNames, isSpaceAdmin, menus, otherMenuApps, otherMenus, psets, ref, ref1, result, userProfile;\n psets = this.psetsCurrent || Creator.getCollection(\"permission_set\").find({\n users: userId,\n space: spaceId\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1,\n name: 1\n }\n }).fetch();\n isSpaceAdmin = _.isBoolean(this.isSpaceAdmin) ? this.isSpaceAdmin : Creator.isSpaceAdmin(spaceId, userId);\n adminMenus = (ref = Creator.Apps.admin) != null ? ref.admin_menus : void 0;\n if (!adminMenus) {\n return [];\n }\n aboutMenu = adminMenus.find(function(n) {\n return n._id === 'about';\n });\n adminMenus = adminMenus.filter(function(n) {\n return n._id !== 'about';\n });\n otherMenuApps = _.sortBy(_.filter(_.values(Creator.Apps), function(n) {\n return n.admin_menus && n._id !== 'admin';\n }), 'sort');\n otherMenus = _.flatten(_.pluck(otherMenuApps, \"admin_menus\"));\n allMenus = _.union(adminMenus, otherMenus, [aboutMenu]);\n if (isSpaceAdmin) {\n result = allMenus;\n } else {\n userProfile = ((ref1 = Creator.getCollection(\"space_users\").findOne({\n space: spaceId,\n user: userId\n }, {\n fields: {\n profile: 1\n }\n })) != null ? ref1.profile : void 0) || 'user';\n currentPsetNames = psets.map(function(n) {\n return n.name;\n });\n menus = allMenus.filter(function(menu) {\n var psetsMenu;\n psetsMenu = menu.permission_sets;\n if (psetsMenu && psetsMenu.indexOf(userProfile) > -1) {\n return true;\n }\n return _.intersection(currentPsetNames, psetsMenu).length;\n });\n result = menus;\n }\n return _.sortBy(result, \"sort\");\n };\n findOne_permission_object = function(permission_objects, object_name, permission_set_id) {\n if (_.isNull(permission_objects)) {\n return null;\n }\n if (_.isArray(permission_objects)) {\n return _.find(permission_objects, function(po) {\n return po.object_name === object_name;\n });\n }\n return Creator.getCollection(\"permission_objects\").findOne({\n object_name: object_name,\n permission_set_id: permission_set_id\n });\n };\n find_permission_object = function(permission_objects, object_name, permission_set_ids) {\n if (_.isNull(permission_objects)) {\n return null;\n }\n if (_.isArray(permission_objects)) {\n return _.filter(permission_objects, function(po) {\n return po.object_name === object_name;\n });\n }\n return Creator.getCollection(\"permission_objects\").find({\n object_name: object_name,\n permission_set_id: {\n $in: permission_set_ids\n }\n }).fetch();\n };\n unionPermissionObjects = function(pos, object, psets) {\n var result;\n result = [];\n _.each(object.permission_set, function(ops, ops_key) {\n var currentPset, tempOps;\n if ([\"admin\", \"user\", \"member\", \"guest\"].indexOf(ops_key) < 0) {\n currentPset = psets.find(function(pset) {\n return pset.name === ops_key;\n });\n if (currentPset) {\n tempOps = _.clone(ops) || {};\n tempOps.permission_set_id = currentPset._id;\n tempOps.object_name = object.object_name;\n return result.push(tempOps);\n }\n }\n });\n if (result.length) {\n pos.forEach(function(po) {\n var repeatIndex, repeatPo;\n repeatIndex = 0;\n repeatPo = result.find(function(item, index) {\n repeatIndex = index;\n return item.permission_set_id === po.permission_set_id;\n });\n if (repeatPo) {\n return result[repeatIndex] = po;\n } else {\n return result.push(po);\n }\n });\n return result;\n } else {\n return pos;\n }\n };\n Creator.getObjectPermissions = function(spaceId, userId, object_name) {\n var isSpaceAdmin, object, opsetAdmin, opsetCustomer, opsetGuest, opsetMember, opsetSupplier, opsetUser, permissions, pos, posAdmin, posCustomer, posGuest, posMember, posSupplier, posUser, prof, psets, psetsAdmin, psetsAdmin_pos, psetsCurrent_pos, psetsCustomer, psetsCustomer_pos, psetsGuest, psetsGuest_pos, psetsMember, psetsMember_pos, psetsSupplier, psetsSupplier_pos, psetsUser, psetsUser_pos, set_ids, spaceUser;\n permissions = {};\n object = Creator.getObject(object_name, spaceId);\n if (spaceId === 'guest' || object_name === \"users\") {\n permissions = _.clone(object.permission_set.guest) || {};\n Creator.processPermissions(permissions);\n return permissions;\n }\n psetsAdmin = _.isNull(this.psetsAdmin) || this.psetsAdmin ? this.psetsAdmin : Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'admin'\n }, {\n fields: {\n _id: 1\n }\n });\n psetsUser = _.isNull(this.psetsUser) || this.psetsUser ? this.psetsUser : Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'user'\n }, {\n fields: {\n _id: 1\n }\n });\n psetsMember = _.isNull(this.psetsMember) || this.psetsMember ? this.psetsMember : Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'member'\n }, {\n fields: {\n _id: 1\n }\n });\n psetsGuest = _.isNull(this.psetsGuest) || this.psetsGuest ? this.psetsGuest : Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'guest'\n }, {\n fields: {\n _id: 1\n }\n });\n psetsSupplier = _.isNull(this.psetsSupplier) || this.psetsSupplier ? this.psetsSupplier : Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'supplier'\n }, {\n fields: {\n _id: 1\n }\n });\n psetsCustomer = _.isNull(this.psetsCustomer) || this.psetsCustomer ? this.psetsCustomer : Creator.getCollection(\"permission_set\").findOne({\n space: spaceId,\n name: 'customer'\n }, {\n fields: {\n _id: 1\n }\n });\n psets = this.psetsCurrent;\n if (!psets) {\n spaceUser = null;\n if (userId) {\n spaceUser = Creator.getCollection(\"space_users\").findOne({\n space: spaceId,\n user: userId\n }, {\n fields: {\n profile: 1\n }\n });\n }\n if (spaceUser && spaceUser.profile) {\n psets = Creator.getCollection(\"permission_set\").find({\n space: spaceId,\n $or: [\n {\n users: userId\n }, {\n name: spaceUser.profile\n }\n ]\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1,\n name: 1\n }\n }).fetch();\n } else {\n psets = Creator.getCollection(\"permission_set\").find({\n users: userId,\n space: spaceId\n }, {\n fields: {\n _id: 1,\n assigned_apps: 1,\n name: 1\n }\n }).fetch();\n }\n }\n isSpaceAdmin = _.isBoolean(this.isSpaceAdmin) ? this.isSpaceAdmin : Creator.isSpaceAdmin(spaceId, userId);\n psetsAdmin_pos = this.psetsAdmin_pos;\n psetsUser_pos = this.psetsUser_pos;\n psetsMember_pos = this.psetsMember_pos;\n psetsGuest_pos = this.psetsGuest_pos;\n psetsSupplier_pos = this.psetsSupplier_pos;\n psetsCustomer_pos = this.psetsCustomer_pos;\n psetsCurrent_pos = this.psetsCurrent_pos;\n opsetAdmin = _.clone(object.permission_set.admin) || {};\n opsetUser = _.clone(object.permission_set.user) || {};\n opsetMember = _.clone(object.permission_set.member) || {};\n opsetGuest = _.clone(object.permission_set.guest) || {};\n opsetSupplier = _.clone(object.permission_set.supplier) || {};\n opsetCustomer = _.clone(object.permission_set.customer) || {};\n if (psetsAdmin) {\n posAdmin = findOne_permission_object(psetsAdmin_pos, object_name, psetsAdmin._id);\n extendPermissionProps(opsetAdmin, posAdmin);\n }\n if (psetsUser) {\n posUser = findOne_permission_object(psetsUser_pos, object_name, psetsUser._id);\n extendPermissionProps(opsetUser, posUser);\n }\n if (psetsMember) {\n posMember = findOne_permission_object(psetsMember_pos, object_name, psetsMember._id);\n extendPermissionProps(opsetMember, posMember);\n }\n if (psetsGuest) {\n posGuest = findOne_permission_object(psetsGuest_pos, object_name, psetsGuest._id);\n extendPermissionProps(opsetGuest, posGuest);\n }\n if (psetsSupplier) {\n posSupplier = findOne_permission_object(psetsSupplier_pos, object_name, psetsSupplier._id);\n extendPermissionProps(opsetSupplier, posSupplier);\n }\n if (psetsCustomer) {\n posCustomer = findOne_permission_object(psetsCustomer_pos, object_name, psetsCustomer._id);\n extendPermissionProps(opsetCustomer, posCustomer);\n }\n if (!userId) {\n permissions = opsetAdmin;\n } else {\n if (isSpaceAdmin) {\n permissions = opsetAdmin;\n } else {\n if (spaceId === 'common') {\n permissions = opsetUser;\n } else {\n spaceUser = _.isNull(this.spaceUser) || this.spaceUser ? this.spaceUser : Creator.getCollection(\"space_users\").findOne({\n space: spaceId,\n user: userId\n }, {\n fields: {\n profile: 1\n }\n });\n if (spaceUser) {\n prof = spaceUser.profile;\n if (prof) {\n if (prof === 'user') {\n permissions = opsetUser;\n } else if (prof === 'member') {\n permissions = opsetMember;\n } else if (prof === 'guest') {\n permissions = opsetGuest;\n } else if (prof === 'supplier') {\n permissions = opsetSupplier;\n } else if (prof === 'customer') {\n permissions = opsetCustomer;\n }\n } else {\n permissions = opsetUser;\n }\n } else {\n permissions = opsetGuest;\n }\n }\n }\n }\n if (psets.length > 0) {\n set_ids = _.pluck(psets, \"_id\");\n pos = find_permission_object(psetsCurrent_pos, object_name, set_ids);\n pos = unionPermissionObjects(pos, object, psets);\n _.each(pos, function(po) {\n if (po.permission_set_id === (psetsAdmin != null ? psetsAdmin._id : void 0) || po.permission_set_id === (psetsUser != null ? psetsUser._id : void 0) || po.permission_set_id === (psetsMember != null ? psetsMember._id : void 0) || po.permission_set_id === (psetsGuest != null ? psetsGuest._id : void 0) || po.permission_set_id === (psetsSupplier != null ? psetsSupplier._id : void 0) || po.permission_set_id === (psetsCustomer != null ? psetsCustomer._id : void 0)) {\n return;\n }\n if (_.isEmpty(permissions)) {\n permissions = po;\n }\n overlayBaseBooleanPermissionProps(permissions, po);\n permissions.disabled_list_views = intersectionPlus(permissions.disabled_list_views, po.disabled_list_views);\n permissions.disabled_actions = intersectionPlus(permissions.disabled_actions, po.disabled_actions);\n permissions.unreadable_fields = intersectionPlus(permissions.unreadable_fields, po.unreadable_fields);\n permissions.uneditable_fields = intersectionPlus(permissions.uneditable_fields, po.uneditable_fields);\n permissions.unrelated_objects = intersectionPlus(permissions.unrelated_objects, po.unrelated_objects);\n return permissions.uneditable_related_list = intersectionPlus(permissions.uneditable_related_list, po.uneditable_related_list);\n });\n }\n if (object.is_view) {\n permissions.allowCreate = false;\n permissions.allowEdit = false;\n permissions.allowDelete = false;\n permissions.modifyAllRecords = false;\n permissions.modifyCompanyRecords = false;\n permissions.disabled_actions = [];\n }\n Creator.processPermissions(permissions);\n if (object.permission_set.owner) {\n permissions.owner = object.permission_set.owner;\n }\n return permissions;\n };\n Meteor.methods({\n \"creator.object_permissions\": function(spaceId) {\n return Creator.getAllPermissions(spaceId, this.userId);\n }\n });\n}\n","\nsteedosCore = require('@steedos/core')\n\nMeteor.startup ()->\n\tcreator_db_url = process.env.MONGO_URL_CREATOR\n\toplog_url = process.env.MONGO_OPLOG_URL_CREATOR\n\tif creator_db_url\n\t\tif !oplog_url\n\t\t\tthrow new Meteor.Error(500, \"Please configure environment variables: MONGO_OPLOG_URL_CREATOR\")\n\t\tCreator._CREATOR_DATASOURCE = {_driver: new MongoInternals.RemoteCollectionDriver(creator_db_url, {oplogUrl: oplog_url})}\n\nCreator.getCollectionName = (object)->\n#\tif object.table_name && object.table_name.endsWith(\"__c\")\n#\t\treturn object.table_name\n#\telse\n#\t\treturn object.name\n\treturn object.name\nCreator.createCollection = (object)->\n\tcollection_key = Creator.getCollectionName(object)\n\tif db[collection_key]\n\t\treturn db[collection_key]\n\telse if object.db\n\t\treturn object.db\n\n\tif Creator.Collections[collection_key]\n\t\treturn Creator.Collections[collection_key]\n\telse\n\t\tif object.custom\n\t\t\treturn steedosCore.newCollection(collection_key, Creator._CREATOR_DATASOURCE)\n\t\telse\n\t\t\tif collection_key == '_sms_queue' && SMSQueue?.collection\n\t\t\t\treturn SMSQueue.collection\n\t\t\treturn steedosCore.newCollection(collection_key)\n\n\n","var steedosCore;\n\nsteedosCore = require('@steedos/core');\n\nMeteor.startup(function() {\n var creator_db_url, oplog_url;\n creator_db_url = process.env.MONGO_URL_CREATOR;\n oplog_url = process.env.MONGO_OPLOG_URL_CREATOR;\n if (creator_db_url) {\n if (!oplog_url) {\n throw new Meteor.Error(500, \"Please configure environment variables: MONGO_OPLOG_URL_CREATOR\");\n }\n return Creator._CREATOR_DATASOURCE = {\n _driver: new MongoInternals.RemoteCollectionDriver(creator_db_url, {\n oplogUrl: oplog_url\n })\n };\n }\n});\n\nCreator.getCollectionName = function(object) {\n return object.name;\n};\n\nCreator.createCollection = function(object) {\n var collection_key;\n collection_key = Creator.getCollectionName(object);\n if (db[collection_key]) {\n return db[collection_key];\n } else if (object.db) {\n return object.db;\n }\n if (Creator.Collections[collection_key]) {\n return Creator.Collections[collection_key];\n } else {\n if (object.custom) {\n return steedosCore.newCollection(collection_key, Creator._CREATOR_DATASOURCE);\n } else {\n if (collection_key === '_sms_queue' && (typeof SMSQueue !== \"undefined\" && SMSQueue !== null ? SMSQueue.collection : void 0)) {\n return SMSQueue.collection;\n }\n return steedosCore.newCollection(collection_key);\n }\n }\n};\n","Creator.actionsByName = {}\n\nif Meteor.isClient\n\t# 定义全局 actions 函数\t\n\tCreator.actions = (actions)->\n\t\t_.each actions, (todo, action_name)->\n\t\t\tCreator.actionsByName[action_name] = todo \n\n\tCreator.executeAction = (object_name, action, record_id, item_element, list_view_id, record, callback)->\n\t\tif action && action.type == 'word-print'\n\t\t\tif record_id\n\t\t\t\tfilters = ['_id', '=', record_id]\n\t\t\telse\n\t\t\t\tfilters = ObjectGrid.getFilters(object_name, list_view_id, false, null, null)\n\t\t\turl = \"/api/v4/word_templates/\" + action.word_template + \"/print\" + \"?filters=\" + SteedosFilters.formatFiltersToODataQuery(filters);\n\t\t\turl = Steedos.absoluteUrl(url);\n\t\t\treturn window.open(url);\n\n\t\tobj = Creator.getObject(object_name)\n\t\tif action?.todo\n\t\t\tif typeof action.todo == \"string\"\n\t\t\t\ttodo = Creator.actionsByName[action.todo]\n\t\t\telse if typeof action.todo == \"function\"\n\t\t\t\ttodo = action.todo\t\n\t\t\tif !record && object_name && record_id\n\t\t\t\trecord = Creator.odata.get(object_name, record_id)\n\t\t\tif todo\n\t\t\t\t# item_element为空时应该设置默认值(对象的name字段),否则moreArgs拿到的后续参数位置就不对\n\t\t\t\titem_element = if item_element then item_element else \"\"\n\t\t\t\tmoreArgs = Array.prototype.slice.call(arguments, 3)\n\t\t\t\ttodoArgs = [object_name, record_id].concat(moreArgs)\n\t\t\t\ttodo.apply {\n\t\t\t\t\tobject_name: object_name\n\t\t\t\t\trecord_id: record_id\n\t\t\t\t\tobject: obj\n\t\t\t\t\taction: action\n\t\t\t\t\titem_element: item_element\n\t\t\t\t\trecord: record\n\t\t\t\t}, todoArgs\n\t\t\telse\n\t\t\t\ttoastr.warning(t(\"_object_actions_none_todo\"))\n\t\telse\n\t\t\ttoastr.warning(t(\"_object_actions_none_todo\"))\n\n\n\t_deleteRecord = (object_name, record_id, record_title, list_view_id, record, call_back, call_back_error)->\n\t\t# console.log(\"===_deleteRecord===\", object_name, record_id, record_title, list_view_id, record, call_back, call_back_error);\n\t\tobject = Creator.getObject(object_name)\n\t\tpreviousDoc = FormManager.getPreviousDoc(object_name, record_id, 'delete')\n\t\tCreator.odata.delete object_name, record_id, ()->\n\t\t\tif record_title\n\t\t\t\t# info = object.label + \"\\\"#{record_title}\\\"\" + \"已删除\"\n\t\t\t\tinfo =t \"creator_record_remove_swal_title_suc\", object.label + \"\\\"#{record_title}\\\"\"\n\t\t\telse\n\t\t\t\tinfo = t('creator_record_remove_swal_suc')\n\t\t\ttoastr.success info\n\t\t\tif call_back and typeof call_back == \"function\"\n\t\t\t\tcall_back()\n\n\t\t\tFormManager.runHook(object_name, 'delete', 'after', {_id: record_id, previousDoc: previousDoc})\n\t\t, (error)->\n\t\t\tif call_back_error and typeof call_back_error == \"function\"\n\t\t\t\tcall_back_error()\n\t\t\tFormManager.runHook(object_name, 'delete', 'error', {_id: record_id, error: error})\n\n\tCreator.relatedObjectStandardNew = (related_object_name)->\n\t\trelateObject = Creator.getObject(related_object_name)\n\t\tcollection_name = relateObject.label\n\t\tcollection = \"Creator.Collections.#{Creator.getObject(related_object_name)._collection_name}\"\n\t\tcurrent_object_name = Session.get(\"object_name\")\n\t\tcurrent_record_id = Session.get(\"record_id\")\n\t\tids = Creator.TabularSelectedIds[related_object_name]\n\t\tinitialValues = {};\n\t\tif ids?.length\n\t\t\t# 列表有选中项时,取第一个选中项,复制其内容到新建窗口中\n\t\t\t# 这的第一个指的是第一次勾选的选中项,而不是列表中已勾选的第一项\n\t\t\trecord_id = ids[0]\n\t\t\tdoc = Creator.odata.get(related_object_name, record_id)\n\t\t\tinitialValues = doc\n\t\t\t# “保存并新建”操作中自动打开的新窗口中需要再次复制最新的doc内容到新窗口中\n\t\t\tSession.set 'cmShowAgainDuplicated', true\n\t\telse\n\t\t\tdefaultDoc = FormManager.getRelatedInitialValues(current_object_name, current_record_id, related_object_name);\n\t\t\tif !_.isEmpty(defaultDoc)\n\t\t\t\tinitialValues = defaultDoc\n\t\tif relateObject?.version >= 2\n\t\t\treturn SteedosUI.showModal(stores.ComponentRegistry.components.ObjectForm, {\n\t\t\t\tname: \"#{related_object_name}_standard_new_form\",\n\t\t\t\tobjectApiName: related_object_name,\n\t\t\t\ttitle: '新建 ' + relateObject.label,\n\t\t\t\tinitialValues: initialValues,\n\t\t\t\tafterInsert: (result)->\n\t\t\t\t\tsetTimeout(()->\n\t\t\t\t\t\t# ObjectForm有缓存,新建子表记录可能会有汇总字段,需要刷新表单数据\n\t\t\t\t\t\tif Creator.getObject(current_object_name).version > 1\n\t\t\t\t\t\t\tSteedosUI.reloadRecord(current_object_name, current_record_id)\n\t\t\t\t\t\tFlowRouter.reload();\n\t\t\t\t\t, 1);\n\t\t\t\t\treturn true;\n\t\t\t}, null, {iconPath: '/assets/icons'})\n\n\n\t\tif ids?.length\n\t\t\t# 列表有选中项时,取第一个选中项,复制其内容到新建窗口中\n\t\t\t# 这的第一个指的是第一次勾选的选中项,而不是列表中已勾选的第一项\n\t\t\tSession.set 'cmDoc', initialValues\n\t\t\t# “保存并新建”操作中自动打开的新窗口中需要再次复制最新的doc内容到新窗口中\n\t\t\tSession.set 'cmShowAgainDuplicated', true\n\t\telse\n\t\t\tif !_.isEmpty(initialValues)\n\t\t\t\tSession.set 'cmDoc', initialValues\n\n\t\tSession.set(\"action_fields\", undefined)\n\t\tSession.set(\"action_collection\", collection)\n\t\tSession.set(\"action_collection_name\", collection_name)\n\t\tSession.set(\"action_save_and_insert\", false)\n\t\tMeteor.defer ()->\n\t\t\t$(\".creator-add-related\").click()\n\t\treturn\n\n\tCreator.actions \n\t\t# 在此定义全局 actions\n\t\t\"standard_query\": ()->\n\t\t\tModal.show(\"standard_query_modal\")\n\n\t\t\"standard_new\": (object_name, record_id, fields)->\n\t\t\t# current_record_id = Session.get(\"record_id\")\n\t\t\t# if current_record_id\n\t\t\t# \t# amis 相关子表右上角新建\n\t\t\t# \tCreator.relatedObjectStandardNew(object_name)\n\t\t\t# \treturn \n\t\t\tobject = Creator.getObject(object_name);\n\t\t\tgridName = this.action.gridName;\n\t\t\tisRelated = this.action.isRelated;\n\t\t\tif isRelated\n\t\t\t\trelatedFieldName = this.action.relatedFieldName;\n\t\t\t\tmasterRecordId = this.action.masterRecordId;\n\t\t\t\tinitialValues = this.action.initialValues\n\t\t\t\tif !initialValues\n\t\t\t\t\tinitialValues = {};\n\t\t\t\t\tinitialValues[relatedFieldName] = masterRecordId\n\t\t\telse\n\t\t\t\tinitialValues={}\n\t\t\t\tif(gridName)\n\t\t\t\t\tselectedRows = window.gridRefs?[gridName].current?.api?.getSelectedRows()\n\t\t\t\telse\n\t\t\t\t\tselectedRows = window.gridRef?.current?.api?.getSelectedRows()\t\n\t\t\t\t\n\t\t\t\tif selectedRows?.length\n\t\t\t\t\trecord_id = selectedRows[0]._id;\n\t\t\t\t\tif record_id\n\t\t\t\t\t\tinitialValues = Creator.odata.get(object_name, record_id)\n\n\t\t\t\telse\n\t\t\t\t\tinitialValues = FormManager.getInitialValues(object_name)\n\n\t\t\tif object?.version >= 2\n\t\t\t\treturn Steedos.Page.Form.StandardNew.render(Session.get(\"app_id\"), object_name, t('New') + ' ' + object.label, initialValues , {gridName: gridName});\n\t\t\tSession.set 'action_object_name', object_name\n\t\t\tif selectedRows?.length\n\t\t\t\t# 列表有选中项时,取第一个选中项,复制其内容到新建窗口中\n\t\t\t\t# 这的第一个指的是第一次勾选的选中项,而不是列表中已勾选的第一项\n\t\t\t\tSession.set 'cmDoc', initialValues\n\t\t\t\t# “保存并新建”操作中自动打开的新窗口中需要再次复制最新的doc内容到新窗口中\n\t\t\t\tSession.set 'cmShowAgainDuplicated', true\n\t\t\telse\n\t\t\t\tSession.set 'cmDoc', initialValues\n\t\t\tMeteor.defer ()->\n\t\t\t\t$(\".creator-add\").click()\n\t\t\treturn \n\n\t\t\"standard_open_view\": (object_name, record_id, fields)->\n\t\t\thref = Creator.getObjectUrl(object_name, record_id)\n\t\t\tFlowRouter.redirect(href)\n\t\t\treturn false\n\n\t\t\"standard_edit\": (object_name, record_id, fields)->\n\t\t\tif record_id\n\t\t\t\tobject = Creator.getObject(object_name);\n\t\t\t\tif object?.version >= 2\n\t\t\t\t\treturn Steedos.Page.Form.StandardEdit.render(Session.get(\"app_id\"), object_name, t('Edit') + ' ' + object.label, record_id, {\n\t\t\t\t\t\tgridName: this.action.gridName\n\t\t\t\t\t})\n\t\t\t\tif Steedos.isMobile() && false\n#\t\t\t\t\trecord = Creator.getObjectRecord(object_name, record_id)\n#\t\t\t\t\tSession.set 'cmDoc', record\n#\t\t\t\t\tSession.set 'reload_dxlist', false\n\t\t\t\t\tSession.set 'action_object_name', object_name\n\t\t\t\t\tSession.set 'action_record_id', record_id\n\t\t\t\t\tif this.record\n\t\t\t\t\t\tSession.set 'cmDoc', this.record\n\t\t\t\t\tMeteor.defer ()->\n\t\t\t\t\t\t$(\".btn-edit-record\").click()\n\t\t\t\telse\n\t\t\t\t\tSession.set 'action_object_name', object_name\n\t\t\t\t\tSession.set 'action_record_id', record_id\n\t\t\t\t\tif this.record\n\t\t\t\t\t\tSession.set 'cmDoc', this.record\n\t\t\t\t\t\tMeteor.defer ()->\n\t\t\t\t\t\t\t$(\".btn.creator-edit\").click()\n\n\t\t\"standard_delete\": (object_name, record_id, record_title, list_view_id, record, call_back)->\n\t\t\tgridName = this.action.gridName;\n\t\t\t# console.log(\"===standard_delete===\", object_name, record_id, record_title, list_view_id, record, call_back);\n\t\t\tif record_id\n\t\t\t\tbeforeHook = FormManager.runHook(object_name, 'delete', 'before', {_id: record_id})\n\t\t\t\tif !beforeHook\n\t\t\t\t\treturn false;\n\t\t\tobject = Creator.getObject(object_name)\n\t\t\tnameField = object.NAME_FIELD_KEY || \"name\"\n\n\t\t\tunless list_view_id\n\t\t\t\tlist_view_id = Session.get(\"list_view_id\")\n\t\t\tunless list_view_id\n\t\t\t\tlist_view_id = \"all\"\n\n\t\t\tif(!_.isString(record_title) && record_title)\n\t\t\t\trecord_title = record_title[nameField]\n\t\t\t\n\t\t\tif record && !record_title\n\t\t\t\trecord_title = record[nameField]\n\t\t\t\n\t\t\ti18nTitleKey = \"creator_record_remove_swal_title\"\n\t\t\ti18nTextKey = \"creator_record_remove_swal_text\"\n\n\t\t\tunless record_id\n\t\t\t\ti18nTitleKey = \"creator_record_remove_many_swal_title\"\n\t\t\t\ti18nTextKey = \"creator_record_remove_many_swal_text\"\n\n\t\t\t\t# 如果是批量删除,则传入的list_view_id为列表视图的name,用于获取列表选中项\n\t\t\t\t# 主列表规则是\"listview_#{object_name}_#{list_view_id}\",相关表规则是\"related_listview_#{object_name}_#{related_object_name}_#{related_field_name}\"\n\t\t\t\tselectedRecords = SteedosUI.getTableSelectedRows(gridName || list_view_id)\n\t\t\t\tif !selectedRecords || !selectedRecords.length\n\t\t\t\t\ttoastr.warning(t(\"creator_record_remove_many_no_selection\"))\n\t\t\t\t\treturn\n\n\t\t\tif record_title\n\t\t\t\ttext = t i18nTextKey, \"#{object.label} \\\"#{record_title}\\\"\"\n\t\t\telse\n\t\t\t\ttext = t i18nTextKey, \"#{object.label}\"\n\t\t\tswal\n\t\t\t\ttitle: t i18nTitleKey, \"#{object.label}\"\n\t\t\t\ttext: \"
#{text}
\"\n\t\t\t\thtml: true\n\t\t\t\tshowCancelButton:true\n\t\t\t\tconfirmButtonText: t('Delete')\n\t\t\t\tcancelButtonText: t('Cancel')\n\t\t\t\t(option) ->\n\t\t\t\t\tif option\n\t\t\t\t\t\tif record_id\n\t\t\t\t\t\t\t# 单条记录删除\n\t\t\t\t\t\t\t_deleteRecord object_name, record_id, record_title, list_view_id, record, ()->\n\t\t\t\t\t\t\t\t# 文件版本为\"cfs.files.filerecord\",需要替换为\"cfs-files-filerecord\"\n\t\t\t\t\t\t\t\tgridObjectNameClass = object_name.replace(/\\./g,\"-\")\n\t\t\t\t\t\t\t\tgridContainer = $(\".gridContainer.#{gridObjectNameClass}\")\n\t\t\t\t\t\t\t\tunless gridContainer?.length\n\t\t\t\t\t\t\t\t\tif window.opener\n\t\t\t\t\t\t\t\t\t\tisOpenerRemove = false\n\t\t\t\t\t\t\t\t\t\tgridContainer = window.opener.$(\".gridContainer.#{gridObjectNameClass}\")\n\t\t\t\t\t\t\t\ttry\n\t\t\t\t\t\t\t\t\t# ObjectForm有缓存,删除子表记录可能会有汇总字段,需要刷新表单数据\n\t\t\t\t\t\t\t\t\tcurrent_object_name = Session.get(\"object_name\")\n\t\t\t\t\t\t\t\t\tcurrent_record_id = Session.get(\"record_id\")\n\t\t\t\t\t\t\t\t\tif current_object_name && Creator.getObject(current_object_name)?.version > 1\n\t\t\t\t\t\t\t\t\t\tSteedosUI.reloadRecord(current_object_name, current_record_id)\n\t\t\t\t\t\t\t\t\tif FlowRouter.current().route.path.endsWith(\"/:record_id\")\n\t\t\t\t\t\t\t\t\t\tif object_name != Session.get(\"object_name\")\n\t\t\t\t\t\t\t\t\t\t\tFlowRouter.reload();\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\twindow.refreshGrid(gridName);\n\t\t\t\t\t\t\t\tcatch _e\n\t\t\t\t\t\t\t\t\tconsole.error(_e);\n\t\t\t\t\t\t\t\tif gridContainer?.length\n\t\t\t\t\t\t\t\t\tif object.enable_tree\n\t\t\t\t\t\t\t\t\t\tdxDataGridInstance = gridContainer.dxTreeList().dxTreeList('instance')\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tdxDataGridInstance = gridContainer.dxDataGrid().dxDataGrid('instance')\n\t\t\t\t\t\t\t\tif dxDataGridInstance\n\t\t\t\t\t\t\t\t\tif object.enable_tree\n\t\t\t\t\t\t\t\t\t\tdxDataGridInstance.refresh()\n\t\t\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\t\t\tif object_name != Session.get(\"object_name\")\n\t\t\t\t\t\t\t\t\t\t\tFlowRouter.reload();\n\t\t\t\t\t\t\t\t\t\t# else\n\t\t\t\t\t\t\t\t\t\t# \tTemplate.creator_grid.refresh(dxDataGridInstance)\n\t\t\t\t\t\t\t\trecordUrl = Creator.getObjectUrl(object_name, record_id)\n\t\t\t\t\t\t\t\ttempNavRemoved = Creator.removeTempNavItem(object_name, recordUrl) #无论是在记录详细界面还是列表界面执行删除操作,都会把临时导航删除掉\n\t\t\t\t\t\t\t\tif isOpenerRemove or !dxDataGridInstance\n\t\t\t\t\t\t\t\t\tif isOpenerRemove\n\t\t\t\t\t\t\t\t\t\twindow.close()\n\t\t\t\t\t\t\t\t\telse if record_id == Session.get(\"record_id\") and list_view_id != 'calendar'\n\t\t\t\t\t\t\t\t\t\tappid = Session.get(\"app_id\")\n\t\t\t\t\t\t\t\t\t\tunless tempNavRemoved\n\t\t\t\t\t\t\t\t\t\t\t# 如果确实删除了临时导航,就可能已经重定向到上一个页面了,没必要再重定向一次\n\t\t\t\t\t\t\t\t\t\t\tFlowRouter.go \"/app/#{appid}/#{object_name}/grid/#{list_view_id}\"\n\t\t\t\t\t\t\t\tif call_back and typeof call_back == \"function\"\n\t\t\t\t\t\t\t\t\tcall_back()\t\t\t\n\t\t\t\t\t\telse\n\t\t\t\t\t\t\t# 批量删除\n\t\t\t\t\t\t\tif selectedRecords && selectedRecords.length\n\t\t\t\t\t\t\t\t$(\"body\").addClass(\"loading\")\n\t\t\t\t\t\t\t\tdeleteCounter = 0;\n\t\t\t\t\t\t\t\tafterBatchesDelete = ()->\n\t\t\t\t\t\t\t\t\tdeleteCounter++\n\t\t\t\t\t\t\t\t\tif deleteCounter >= selectedRecords.length\n\t\t\t\t\t\t\t\t\t\t# console.log(\"deleteCounter, selectedRecords.length===\", deleteCounter, selectedRecords.length);\n\t\t\t\t\t\t\t\t\t\t$(\"body\").removeClass(\"loading\")\n\t\t\t\t\t\t\t\t\t\twindow.refreshGrid(gridName);\n\t\t\t\t\t\t\t\tselectedRecords.forEach (record)->\n\t\t\t\t\t\t\t\t\trecord_id = record._id\n\t\t\t\t\t\t\t\t\tbeforeHook = FormManager.runHook(object_name, 'delete', 'before', {_id: record_id})\n\t\t\t\t\t\t\t\t\tif !beforeHook\n\t\t\t\t\t\t\t\t\t\tafterBatchesDelete()\n\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\trecordTitle = record[nameField] || record_id\n\t\t\t\t\t\t\t\t\t_deleteRecord object_name, record._id, recordTitle, list_view_id, record, (()->\n\t\t\t\t\t\t\t\t\t\trecordUrl = Creator.getObjectUrl(object_name, record_id)\n\t\t\t\t\t\t\t\t\t\tCreator.removeTempNavItem(object_name, recordUrl) #无论是在记录详细界面还是列表界面执行删除操作,都会把临时导航删除掉\n\t\t\t\t\t\t\t\t\t\tafterBatchesDelete()\n\t\t\t\t\t\t\t\t\t), ()->\n\t\t\t\t\t\t\t\t\t\tafterBatchesDelete()","var _deleteRecord;\n\nCreator.actionsByName = {};\n\nif (Meteor.isClient) {\n Creator.actions = function(actions) {\n return _.each(actions, function(todo, action_name) {\n return Creator.actionsByName[action_name] = todo;\n });\n };\n Creator.executeAction = function(object_name, action, record_id, item_element, list_view_id, record, callback) {\n var filters, moreArgs, obj, todo, todoArgs, url;\n if (action && action.type === 'word-print') {\n if (record_id) {\n filters = ['_id', '=', record_id];\n } else {\n filters = ObjectGrid.getFilters(object_name, list_view_id, false, null, null);\n }\n url = \"/api/v4/word_templates/\" + action.word_template + \"/print\" + \"?filters=\" + SteedosFilters.formatFiltersToODataQuery(filters);\n url = Steedos.absoluteUrl(url);\n return window.open(url);\n }\n obj = Creator.getObject(object_name);\n if (action != null ? action.todo : void 0) {\n if (typeof action.todo === \"string\") {\n todo = Creator.actionsByName[action.todo];\n } else if (typeof action.todo === \"function\") {\n todo = action.todo;\n }\n if (!record && object_name && record_id) {\n record = Creator.odata.get(object_name, record_id);\n }\n if (todo) {\n item_element = item_element ? item_element : \"\";\n moreArgs = Array.prototype.slice.call(arguments, 3);\n todoArgs = [object_name, record_id].concat(moreArgs);\n return todo.apply({\n object_name: object_name,\n record_id: record_id,\n object: obj,\n action: action,\n item_element: item_element,\n record: record\n }, todoArgs);\n } else {\n return toastr.warning(t(\"_object_actions_none_todo\"));\n }\n } else {\n return toastr.warning(t(\"_object_actions_none_todo\"));\n }\n };\n _deleteRecord = function(object_name, record_id, record_title, list_view_id, record, call_back, call_back_error) {\n var object, previousDoc;\n object = Creator.getObject(object_name);\n previousDoc = FormManager.getPreviousDoc(object_name, record_id, 'delete');\n return Creator.odata[\"delete\"](object_name, record_id, function() {\n var info;\n if (record_title) {\n info = t(\"creator_record_remove_swal_title_suc\", object.label + (\"\\\"\" + record_title + \"\\\"\"));\n } else {\n info = t('creator_record_remove_swal_suc');\n }\n toastr.success(info);\n if (call_back && typeof call_back === \"function\") {\n call_back();\n }\n return FormManager.runHook(object_name, 'delete', 'after', {\n _id: record_id,\n previousDoc: previousDoc\n });\n }, function(error) {\n if (call_back_error && typeof call_back_error === \"function\") {\n call_back_error();\n }\n return FormManager.runHook(object_name, 'delete', 'error', {\n _id: record_id,\n error: error\n });\n });\n };\n Creator.relatedObjectStandardNew = function(related_object_name) {\n var collection, collection_name, current_object_name, current_record_id, defaultDoc, doc, ids, initialValues, record_id, relateObject;\n relateObject = Creator.getObject(related_object_name);\n collection_name = relateObject.label;\n collection = \"Creator.Collections.\" + (Creator.getObject(related_object_name)._collection_name);\n current_object_name = Session.get(\"object_name\");\n current_record_id = Session.get(\"record_id\");\n ids = Creator.TabularSelectedIds[related_object_name];\n initialValues = {};\n if (ids != null ? ids.length : void 0) {\n record_id = ids[0];\n doc = Creator.odata.get(related_object_name, record_id);\n initialValues = doc;\n Session.set('cmShowAgainDuplicated', true);\n } else {\n defaultDoc = FormManager.getRelatedInitialValues(current_object_name, current_record_id, related_object_name);\n if (!_.isEmpty(defaultDoc)) {\n initialValues = defaultDoc;\n }\n }\n if ((relateObject != null ? relateObject.version : void 0) >= 2) {\n return SteedosUI.showModal(stores.ComponentRegistry.components.ObjectForm, {\n name: related_object_name + \"_standard_new_form\",\n objectApiName: related_object_name,\n title: '新建 ' + relateObject.label,\n initialValues: initialValues,\n afterInsert: function(result) {\n setTimeout(function() {\n if (Creator.getObject(current_object_name).version > 1) {\n SteedosUI.reloadRecord(current_object_name, current_record_id);\n }\n return FlowRouter.reload();\n }, 1);\n return true;\n }\n }, null, {\n iconPath: '/assets/icons'\n });\n }\n if (ids != null ? ids.length : void 0) {\n Session.set('cmDoc', initialValues);\n Session.set('cmShowAgainDuplicated', true);\n } else {\n if (!_.isEmpty(initialValues)) {\n Session.set('cmDoc', initialValues);\n }\n }\n Session.set(\"action_fields\", void 0);\n Session.set(\"action_collection\", collection);\n Session.set(\"action_collection_name\", collection_name);\n Session.set(\"action_save_and_insert\", false);\n Meteor.defer(function() {\n return $(\".creator-add-related\").click();\n });\n };\n Creator.actions({\n \"standard_query\": function() {\n return Modal.show(\"standard_query_modal\");\n },\n \"standard_new\": function(object_name, record_id, fields) {\n var gridName, initialValues, isRelated, masterRecordId, object, ref, ref1, ref2, ref3, ref4, ref5, relatedFieldName, selectedRows;\n object = Creator.getObject(object_name);\n gridName = this.action.gridName;\n isRelated = this.action.isRelated;\n if (isRelated) {\n relatedFieldName = this.action.relatedFieldName;\n masterRecordId = this.action.masterRecordId;\n initialValues = this.action.initialValues;\n if (!initialValues) {\n initialValues = {};\n initialValues[relatedFieldName] = masterRecordId;\n }\n } else {\n initialValues = {};\n if (gridName) {\n selectedRows = (ref = window.gridRefs) != null ? (ref1 = ref[gridName].current) != null ? (ref2 = ref1.api) != null ? ref2.getSelectedRows() : void 0 : void 0 : void 0;\n } else {\n selectedRows = (ref3 = window.gridRef) != null ? (ref4 = ref3.current) != null ? (ref5 = ref4.api) != null ? ref5.getSelectedRows() : void 0 : void 0 : void 0;\n }\n if (selectedRows != null ? selectedRows.length : void 0) {\n record_id = selectedRows[0]._id;\n if (record_id) {\n initialValues = Creator.odata.get(object_name, record_id);\n }\n } else {\n initialValues = FormManager.getInitialValues(object_name);\n }\n }\n if ((object != null ? object.version : void 0) >= 2) {\n return Steedos.Page.Form.StandardNew.render(Session.get(\"app_id\"), object_name, t('New') + ' ' + object.label, initialValues, {\n gridName: gridName\n });\n }\n Session.set('action_object_name', object_name);\n if (selectedRows != null ? selectedRows.length : void 0) {\n Session.set('cmDoc', initialValues);\n Session.set('cmShowAgainDuplicated', true);\n } else {\n Session.set('cmDoc', initialValues);\n }\n Meteor.defer(function() {\n return $(\".creator-add\").click();\n });\n },\n \"standard_open_view\": function(object_name, record_id, fields) {\n var href;\n href = Creator.getObjectUrl(object_name, record_id);\n FlowRouter.redirect(href);\n return false;\n },\n \"standard_edit\": function(object_name, record_id, fields) {\n var object;\n if (record_id) {\n object = Creator.getObject(object_name);\n if ((object != null ? object.version : void 0) >= 2) {\n return Steedos.Page.Form.StandardEdit.render(Session.get(\"app_id\"), object_name, t('Edit') + ' ' + object.label, record_id, {\n gridName: this.action.gridName\n });\n }\n if (Steedos.isMobile() && false) {\n Session.set('action_object_name', object_name);\n Session.set('action_record_id', record_id);\n if (this.record) {\n Session.set('cmDoc', this.record);\n }\n return Meteor.defer(function() {\n return $(\".btn-edit-record\").click();\n });\n } else {\n Session.set('action_object_name', object_name);\n Session.set('action_record_id', record_id);\n if (this.record) {\n Session.set('cmDoc', this.record);\n return Meteor.defer(function() {\n return $(\".btn.creator-edit\").click();\n });\n }\n }\n }\n },\n \"standard_delete\": function(object_name, record_id, record_title, list_view_id, record, call_back) {\n var beforeHook, gridName, i18nTextKey, i18nTitleKey, nameField, object, selectedRecords, text;\n gridName = this.action.gridName;\n if (record_id) {\n beforeHook = FormManager.runHook(object_name, 'delete', 'before', {\n _id: record_id\n });\n if (!beforeHook) {\n return false;\n }\n }\n object = Creator.getObject(object_name);\n nameField = object.NAME_FIELD_KEY || \"name\";\n if (!list_view_id) {\n list_view_id = Session.get(\"list_view_id\");\n }\n if (!list_view_id) {\n list_view_id = \"all\";\n }\n if (!_.isString(record_title) && record_title) {\n record_title = record_title[nameField];\n }\n if (record && !record_title) {\n record_title = record[nameField];\n }\n i18nTitleKey = \"creator_record_remove_swal_title\";\n i18nTextKey = \"creator_record_remove_swal_text\";\n if (!record_id) {\n i18nTitleKey = \"creator_record_remove_many_swal_title\";\n i18nTextKey = \"creator_record_remove_many_swal_text\";\n selectedRecords = SteedosUI.getTableSelectedRows(gridName || list_view_id);\n if (!selectedRecords || !selectedRecords.length) {\n toastr.warning(t(\"creator_record_remove_many_no_selection\"));\n return;\n }\n }\n if (record_title) {\n text = t(i18nTextKey, object.label + \" \\\"\" + record_title + \"\\\"\");\n } else {\n text = t(i18nTextKey, \"\" + object.label);\n }\n return swal({\n title: t(i18nTitleKey, \"\" + object.label),\n text: \"
\" + text + \"
\",\n html: true,\n showCancelButton: true,\n confirmButtonText: t('Delete'),\n cancelButtonText: t('Cancel')\n }, function(option) {\n var afterBatchesDelete, deleteCounter;\n if (option) {\n if (record_id) {\n return _deleteRecord(object_name, record_id, record_title, list_view_id, record, function() {\n var _e, appid, current_object_name, current_record_id, dxDataGridInstance, gridContainer, gridObjectNameClass, isOpenerRemove, recordUrl, ref, tempNavRemoved;\n gridObjectNameClass = object_name.replace(/\\./g, \"-\");\n gridContainer = $(\".gridContainer.\" + gridObjectNameClass);\n if (!(gridContainer != null ? gridContainer.length : void 0)) {\n if (window.opener) {\n isOpenerRemove = false;\n gridContainer = window.opener.$(\".gridContainer.\" + gridObjectNameClass);\n }\n }\n try {\n current_object_name = Session.get(\"object_name\");\n current_record_id = Session.get(\"record_id\");\n if (current_object_name && ((ref = Creator.getObject(current_object_name)) != null ? ref.version : void 0) > 1) {\n SteedosUI.reloadRecord(current_object_name, current_record_id);\n }\n if (FlowRouter.current().route.path.endsWith(\"/:record_id\")) {\n if (object_name !== Session.get(\"object_name\")) {\n FlowRouter.reload();\n }\n } else {\n window.refreshGrid(gridName);\n }\n } catch (error1) {\n _e = error1;\n console.error(_e);\n }\n if (gridContainer != null ? gridContainer.length : void 0) {\n if (object.enable_tree) {\n dxDataGridInstance = gridContainer.dxTreeList().dxTreeList('instance');\n } else {\n dxDataGridInstance = gridContainer.dxDataGrid().dxDataGrid('instance');\n }\n }\n if (dxDataGridInstance) {\n if (object.enable_tree) {\n dxDataGridInstance.refresh();\n } else {\n if (object_name !== Session.get(\"object_name\")) {\n FlowRouter.reload();\n }\n }\n }\n recordUrl = Creator.getObjectUrl(object_name, record_id);\n tempNavRemoved = Creator.removeTempNavItem(object_name, recordUrl);\n if (isOpenerRemove || !dxDataGridInstance) {\n if (isOpenerRemove) {\n window.close();\n } else if (record_id === Session.get(\"record_id\") && list_view_id !== 'calendar') {\n appid = Session.get(\"app_id\");\n if (!tempNavRemoved) {\n FlowRouter.go(\"/app/\" + appid + \"/\" + object_name + \"/grid/\" + list_view_id);\n }\n }\n }\n if (call_back && typeof call_back === \"function\") {\n return call_back();\n }\n });\n } else {\n if (selectedRecords && selectedRecords.length) {\n $(\"body\").addClass(\"loading\");\n deleteCounter = 0;\n afterBatchesDelete = function() {\n deleteCounter++;\n if (deleteCounter >= selectedRecords.length) {\n $(\"body\").removeClass(\"loading\");\n return window.refreshGrid(gridName);\n }\n };\n return selectedRecords.forEach(function(record) {\n var recordTitle;\n record_id = record._id;\n beforeHook = FormManager.runHook(object_name, 'delete', 'before', {\n _id: record_id\n });\n if (!beforeHook) {\n afterBatchesDelete();\n return;\n }\n recordTitle = record[nameField] || record_id;\n return _deleteRecord(object_name, record._id, recordTitle, list_view_id, record, (function() {\n var recordUrl;\n recordUrl = Creator.getObjectUrl(object_name, record_id);\n Creator.removeTempNavItem(object_name, recordUrl);\n return afterBatchesDelete();\n }), function() {\n return afterBatchesDelete();\n });\n });\n }\n }\n }\n });\n }\n });\n}\n"]} \ No newline at end of file diff --git a/server/bundle/programs/web.browser.legacy/0e8e091408993e566bde6016e2c1649202635d18.js b/server/bundle/programs/web.browser.legacy/46d6afbfa6d571fa8e0eb86d000d02178fdf01c3.js similarity index 87% rename from server/bundle/programs/web.browser.legacy/0e8e091408993e566bde6016e2c1649202635d18.js rename to server/bundle/programs/web.browser.legacy/46d6afbfa6d571fa8e0eb86d000d02178fdf01c3.js index ccc3be90dd..67e9b7ca31 100644 --- a/server/bundle/programs/web.browser.legacy/0e8e091408993e566bde6016e2c1649202635d18.js +++ b/server/bundle/programs/web.browser.legacy/46d6afbfa6d571fa8e0eb86d000d02178fdf01c3.js @@ -31,14 +31,14 @@ Package._define("blaze-html-templates"); * * Date: 2015-10-17 */ -function(e){var t,n,r,i,o,s,a,u,f,c,l,h,d,p,g,b,m,v,y,_="sizzle"+1*new Date,w=e.document,k=0,j=0,x=oe(),S=oe(),D=oe(),E=function(e,t){return e===t&&(l=!0),0},A=1<<31,C={}.hasOwnProperty,M=[],O=M.pop,T=M.push,B=M.push,I=M.slice,R=function(e,t){for(var n=0,r=e.length;n+~]|"+P+")"+P+"*"),W=new RegExp("="+P+"*([^\\]'\"]*?)"+P+"*\\]","g"),Y=new RegExp(z),V=new RegExp("^"+N+"$"),K={ID:new RegExp("^#("+N+")"),CLASS:new RegExp("^\\.("+N+")"),TAG:new RegExp("^("+N+"|[*])"),ATTR:new RegExp("^"+L),PSEUDO:new RegExp("^"+z),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+P+"*(even|odd|(([+-]|)(\\d*)n|)"+P+"*(?:([+-]|)"+P+"*(\\d+)|))"+P+"*\\)|)","i"),bool:new RegExp("^(?:"+F+")$","i"),needsContext:new RegExp("^"+P+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+P+"*((?:-\\d)?\\d*)"+P+"*\\)|)(?=[^-]|$)","i")},G=/^(?:input|select|textarea|button)$/i,X=/^h\d$/i,Z=/^[^{]+\{\s*\[native \w/,J=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,Q=/[+~]/,ee=/'|\\/g,te=new RegExp("\\\\([\\da-f]{1,6}"+P+"?|("+P+")|.)","ig"),ne=function(e,t,n){var r="0x"+t-65536;return r!=r||n?t:r<0?String.fromCharCode(r+65536):String.fromCharCode(r>>10|55296,1023&r|56320)},re=function(){h()};try{B.apply(M=I.call(w.childNodes),w.childNodes),M[w.childNodes.length].nodeType}catch(je){B={apply:M.length?function(e,t){T.apply(e,I.call(t))}:function(e,t){for(var n=e.length,r=0;e[n++]=t[r++];);e.length=n-1}}}function ie(e,t,r,i){var o,a,f,c,l,p,m,v,k=t&&t.ownerDocument,j=t?t.nodeType:9;if(r=r||[],"string"!=typeof e||!e||1!==j&&9!==j&&11!==j)return r;if(!i&&((t?t.ownerDocument||t:w)!==d&&h(t),t=t||d,g)){if(11!==j&&(p=J.exec(e)))if(o=p[1]){if(9===j){if(!(f=t.getElementById(o)))return r;if(f.id===o)return r.push(f),r}else if(k&&(f=k.getElementById(o))&&y(t,f)&&f.id===o)return r.push(f),r}else{if(p[2])return B.apply(r,t.getElementsByTagName(e)),r;if((o=p[3])&&n.getElementsByClassName&&t.getElementsByClassName)return B.apply(r,t.getElementsByClassName(o)),r}if(n.qsa&&!D[e+" "]&&(!b||!b.test(e))){if(1!==j)k=t,v=e;else if("object"!==t.nodeName.toLowerCase()){for((c=t.getAttribute("id"))?c=c.replace(ee,"\\$&"):t.setAttribute("id",c=_),a=(m=s(e)).length,l=V.test(c)?"#"+c:"[id='"+c+"']";a--;)m[a]=l+" "+ge(m[a]);v=m.join(","),k=Q.test(e)&&de(t.parentNode)||t}if(v)try{return B.apply(r,k.querySelectorAll(v)),r}catch(x){}finally{c===_&&t.removeAttribute("id")}}}return u(e.replace(q,"$1"),t,r,i)}function oe(){var e=[];function t(n,i){return e.push(n+" ")>r.cacheLength&&delete t[e.shift()],t[n+" "]=i}return t}function se(e){return e[_]=!0,e}function ae(e){var t=d.createElement("div");try{return!!e(t)}catch(je){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function ue(e,t){for(var n=e.split("|"),i=n.length;i--;)r.attrHandle[n[i]]=t}function fe(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&(~t.sourceIndex||A)-(~e.sourceIndex||A);if(r)return r;if(n)for(;n=n.nextSibling;)if(n===t)return-1;return e?1:-1}function ce(e){return function(t){var n;return"input"===t.nodeName.toLowerCase()&&t.type===e}}function le(e){return function(t){var n=t.nodeName.toLowerCase();return("input"===n||"button"===n)&&t.type===e}}function he(e){return se((function(t){return t=+t,se((function(n,r){for(var i,o=e([],n.length,t),s=o.length;s--;)n[i=o[s]]&&(n[i]=!(r[i]=n[i]))}))}))}function de(e){return e&&void 0!==e.getElementsByTagName&&e}for(t in n=ie.support={},o=ie.isXML=function(e){var t=e&&(e.ownerDocument||e).documentElement;return!!t&&"HTML"!==t.nodeName},h=ie.setDocument=function(e){var t,i,s=e?e.ownerDocument||e:w;return s!==d&&9===s.nodeType&&s.documentElement?(p=(d=s).documentElement,g=!o(d),(i=d.defaultView)&&i.top!==i&&(i.addEventListener?i.addEventListener("unload",re,!1):i.attachEvent&&i.attachEvent("onunload",re)),n.attributes=ae((function(e){return e.className="i",!e.getAttribute("className")})),n.getElementsByTagName=ae((function(e){return e.appendChild(d.createComment("")),!e.getElementsByTagName("*").length})),n.getElementsByClassName=Z.test(d.getElementsByClassName),n.getById=ae((function(e){return p.appendChild(e).id=_,!d.getElementsByName||!d.getElementsByName(_).length})),n.getById?(r.find.ID=function(e,t){if(void 0!==t.getElementById&&g){var n=t.getElementById(e);return n?[n]:[]}},r.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute("id")===t}}):(delete r.find.ID,r.filter.ID=function(e){var t=e.replace(te,ne);return function(e){var n=void 0!==e.getAttributeNode&&e.getAttributeNode("id");return n&&n.value===t}}),r.find.TAG=n.getElementsByTagName?function(e,t){return void 0!==t.getElementsByTagName?t.getElementsByTagName(e):n.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){for(;n=o[i++];)1===n.nodeType&&r.push(n);return r}return o},r.find.CLASS=n.getElementsByClassName&&function(e,t){if(void 0!==t.getElementsByClassName&&g)return t.getElementsByClassName(e)},m=[],b=[],(n.qsa=Z.test(d.querySelectorAll))&&(ae((function(e){p.appendChild(e).innerHTML="",e.querySelectorAll("[msallowcapture^='']").length&&b.push("[*^$]="+P+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||b.push("\\["+P+"*(?:value|"+F+")"),e.querySelectorAll("[id~="+_+"-]").length||b.push("~="),e.querySelectorAll(":checked").length||b.push(":checked"),e.querySelectorAll("a#"+_+"+*").length||b.push(".#.+[+~]")})),ae((function(e){var t=d.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&b.push("name"+P+"*[*^$|!~]?="),e.querySelectorAll(":enabled").length||b.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),b.push(",.*:")}))),(n.matchesSelector=Z.test(v=p.matches||p.webkitMatchesSelector||p.mozMatchesSelector||p.oMatchesSelector||p.msMatchesSelector))&&ae((function(e){n.disconnectedMatch=v.call(e,"div"),v.call(e,"[s!='']:x"),m.push("!=",z)})),b=b.length&&new RegExp(b.join("|")),m=m.length&&new RegExp(m.join("|")),t=Z.test(p.compareDocumentPosition),y=t||Z.test(p.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)for(;t=t.parentNode;)if(t===e)return!0;return!1},E=t?function(e,t){if(e===t)return l=!0,0;var r=!e.compareDocumentPosition-!t.compareDocumentPosition;return r||(1&(r=(e.ownerDocument||e)===(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!n.sortDetached&&t.compareDocumentPosition(e)===r?e===d||e.ownerDocument===w&&y(w,e)?-1:t===d||t.ownerDocument===w&&y(w,t)?1:c?R(c,e)-R(c,t):0:4&r?-1:1)}:function(e,t){if(e===t)return l=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,s=[e],a=[t];if(!i||!o)return e===d?-1:t===d?1:i?-1:o?1:c?R(c,e)-R(c,t):0;if(i===o)return fe(e,t);for(n=e;n=n.parentNode;)s.unshift(n);for(n=t;n=n.parentNode;)a.unshift(n);for(;s[r]===a[r];)r++;return r?fe(s[r],a[r]):s[r]===w?-1:a[r]===w?1:0},d):d},ie.matches=function(e,t){return ie(e,null,null,t)},ie.matchesSelector=function(e,t){if((e.ownerDocument||e)!==d&&h(e),t=t.replace(W,"='$1']"),n.matchesSelector&&g&&!D[t+" "]&&(!m||!m.test(t))&&(!b||!b.test(t)))try{var r=v.call(e,t);if(r||n.disconnectedMatch||e.document&&11!==e.document.nodeType)return r}catch(je){}return ie(t,d,null,[e]).length>0},ie.contains=function(e,t){return(e.ownerDocument||e)!==d&&h(e),y(e,t)},ie.attr=function(e,t){(e.ownerDocument||e)!==d&&h(e);var i=r.attrHandle[t.toLowerCase()],o=i&&C.call(r.attrHandle,t.toLowerCase())?i(e,t,!g):void 0;return void 0!==o?o:n.attributes||!g?e.getAttribute(t):(o=e.getAttributeNode(t))&&o.specified?o.value:null},ie.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},ie.uniqueSort=function(e){var t,r=[],i=0,o=0;if(l=!n.detectDuplicates,c=!n.sortStable&&e.slice(0),e.sort(E),l){for(;t=e[o++];)t===e[o]&&(i=r.push(o));for(;i--;)e.splice(r[i],1)}return c=null,e},i=ie.getText=function(e){var t,n="",r=0,o=e.nodeType;if(o){if(1===o||9===o||11===o){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=i(e)}else if(3===o||4===o)return e.nodeValue}else for(;t=e[r++];)n+=i(t);return n},(r=ie.selectors={cacheLength:50,createPseudo:se,match:K,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||"").replace(te,ne),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||ie.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&ie.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return K.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&Y.test(n)&&(t=s(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=x[e+" "];return t||(t=new RegExp("(^|"+P+")"+e+"("+P+"|$)"))&&x(e,(function(e){return t.test("string"==typeof e.className&&e.className||void 0!==e.getAttribute&&e.getAttribute("class")||"")}))},ATTR:function(e,t,n){return function(r){var i=ie.attr(r,e);return null==i?"!="===t:!t||(i+="","="===t?i===n:"!="===t?i!==n:"^="===t?n&&0===i.indexOf(n):"*="===t?n&&i.indexOf(n)>-1:"$="===t?n&&i.slice(-n.length)===n:"~="===t?(" "+i.replace(U," ")+" ").indexOf(n)>-1:"|="===t&&(i===n||i.slice(0,n.length+1)===n+"-"))}},CHILD:function(e,t,n,r,i){var o="nth"!==e.slice(0,3),s="last"!==e.slice(-4),a="of-type"===t;return 1===r&&0===i?function(e){return!!e.parentNode}:function(t,n,u){var f,c,l,h,d,p,g=o!==s?"nextSibling":"previousSibling",b=t.parentNode,m=a&&t.nodeName.toLowerCase(),v=!u&&!a,y=!1;if(b){if(o){for(;g;){for(h=t;h=h[g];)if(a?h.nodeName.toLowerCase()===m:1===h.nodeType)return!1;p=g="only"===e&&!p&&"nextSibling"}return!0}if(p=[s?b.firstChild:b.lastChild],s&&v){for(y=(d=(f=(c=(l=(h=b)[_]||(h[_]={}))[h.uniqueID]||(l[h.uniqueID]={}))[e]||[])[0]===k&&f[1])&&f[2],h=d&&b.childNodes[d];h=++d&&h&&h[g]||(y=d=0)||p.pop();)if(1===h.nodeType&&++y&&h===t){c[e]=[k,d,y];break}}else if(v&&(y=d=(f=(c=(l=(h=t)[_]||(h[_]={}))[h.uniqueID]||(l[h.uniqueID]={}))[e]||[])[0]===k&&f[1]),!1===y)for(;(h=++d&&h&&h[g]||(y=d=0)||p.pop())&&((a?h.nodeName.toLowerCase()!==m:1!==h.nodeType)||!++y||(v&&((c=(l=h[_]||(h[_]={}))[h.uniqueID]||(l[h.uniqueID]={}))[e]=[k,y]),h!==t)););return(y-=i)===r||y%r==0&&y/r>=0}}},PSEUDO:function(e,t){var n,i=r.pseudos[e]||r.setFilters[e.toLowerCase()]||ie.error("unsupported pseudo: "+e);return i[_]?i(t):i.length>1?(n=[e,e,"",t],r.setFilters.hasOwnProperty(e.toLowerCase())?se((function(e,n){for(var r,o=i(e,t),s=o.length;s--;)e[r=R(e,o[s])]=!(n[r]=o[s])})):function(e){return i(e,0,n)}):i}},pseudos:{not:se((function(e){var t=[],n=[],r=a(e.replace(q,"$1"));return r[_]?se((function(e,t,n,i){for(var o,s=r(e,null,i,[]),a=e.length;a--;)(o=s[a])&&(e[a]=!(t[a]=o))})):function(e,i,o){return t[0]=e,r(t,null,o,n),t[0]=null,!n.pop()}})),has:se((function(e){return function(t){return ie(e,t).length>0}})),contains:se((function(e){return e=e.replace(te,ne),function(t){return(t.textContent||t.innerText||i(t)).indexOf(e)>-1}})),lang:se((function(e){return V.test(e||"")||ie.error("unsupported lang: "+e),e=e.replace(te,ne).toLowerCase(),function(t){var n;do{if(n=g?t.lang:t.getAttribute("xml:lang")||t.getAttribute("lang"))return(n=n.toLowerCase())===e||0===n.indexOf(e+"-")}while((t=t.parentNode)&&1===t.nodeType);return!1}})),target:function(t){var n=e.location&&e.location.hash;return n&&n.slice(1)===t.id},root:function(e){return e===p},focus:function(e){return e===d.activeElement&&(!d.hasFocus||d.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:function(e){return!1===e.disabled},disabled:function(e){return!0===e.disabled},checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!r.pseudos.empty(e)},header:function(e){return X.test(e.nodeName)},input:function(e){return G.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:he((function(){return[0]})),last:he((function(e,t){return[t-1]})),eq:he((function(e,t,n){return[n<0?n+t:n]})),even:he((function(e,t){for(var n=0;n=0;)e.push(r);return e})),gt:he((function(e,t,n){for(var r=n<0?n+t:n;++r1?function(t,n,r){for(var i=e.length;i--;)if(!e[i](t,n,r))return!1;return!0}:e[0]}function ve(e,t,n){for(var r=0,i=t.length;r-1&&(o[f]=!(s[f]=l))}}else m=ye(m===s?m.splice(p,m.length):m),i?i(null,s,m,u):B.apply(s,m)}))}function we(e){for(var t,n,i,o=e.length,s=r.relative[e[0].type],a=s||r.relative[" "],u=s?1:0,c=be((function(e){return e===t}),a,!0),l=be((function(e){return R(t,e)>-1}),a,!0),h=[function(e,n,r){var i=!s&&(r||n!==f)||((t=n).nodeType?c(e,n,r):l(e,n,r));return t=null,i}];u1&&me(h),u>1&&ge(e.slice(0,u-1).concat({value:" "===e[u-2].type?"*":""})).replace(q,"$1"),n,u0,i=e.length>0,o=function(o,s,a,u,c){var l,p,b,m=0,v="0",y=o&&[],_=[],w=f,j=o||i&&r.find.TAG("*",c),x=k+=null==w?1:Math.random()||.1,S=j.length;for(c&&(f=s===d||s||c);v!==S&&null!=(l=j[v]);v++){if(i&&l){for(p=0,s||l.ownerDocument===d||(h(l),a=!g);b=e[p++];)if(b(l,s||d,a)){u.push(l);break}c&&(k=x)}n&&((l=!b&&l)&&m--,o&&y.push(l))}if(m+=v,n&&v!==m){for(p=0;b=t[p++];)b(y,_,s,a);if(o){if(m>0)for(;v--;)y[v]||_[v]||(_[v]=O.call(u));_=ye(_)}B.apply(u,_),c&&!o&&_.length>0&&m+t.length>1&&ie.uniqueSort(u)}return c&&(k=x,f=w),y};return n?se(o):o}return pe.prototype=r.filters=r.pseudos,r.setFilters=new pe,s=ie.tokenize=function(e,t){var n,i,o,s,a,u,f,c=S[e+" "];if(c)return t?0:c.slice(0);for(a=e,u=[],f=r.preFilter;a;){for(s in n&&!(i=$.exec(a))||(i&&(a=a.slice(i[0].length)||a),u.push(o=[])),n=!1,(i=H.exec(a))&&(n=i.shift(),o.push({value:n,type:i[0].replace(q," ")}),a=a.slice(n.length)),r.filter)!(i=K[s].exec(a))||f[s]&&!(i=f[s](i))||(n=i.shift(),o.push({value:n,type:s,matches:i}),a=a.slice(n.length));if(!n)break}return t?a.length:a?ie.error(e):S(e,u).slice(0)},a=ie.compile=function(e,t){var n,r=[],i=[],o=D[e+" "];if(!o){for(t||(t=s(e)),n=t.length;n--;)(o=we(t[n]))[_]?r.push(o):i.push(o);(o=D(e,ke(i,r))).selector=e}return o},u=ie.select=function(e,t,i,o){var u,f,c,l,h,d="function"==typeof e&&e,p=!o&&s(e=d.selector||e);if(i=i||[],1===p.length){if((f=p[0]=p[0].slice(0)).length>2&&"ID"===(c=f[0]).type&&n.getById&&9===t.nodeType&&g&&r.relative[f[1].type]){if(!(t=(r.find.ID(c.matches[0].replace(te,ne),t)||[])[0]))return i;d&&(t=t.parentNode),e=e.slice(f.shift().value.length)}for(u=K.needsContext.test(e)?0:f.length;u--&&(c=f[u],!r.relative[l=c.type]);)if((h=r.find[l])&&(o=h(c.matches[0].replace(te,ne),Q.test(f[0].type)&&de(t.parentNode)||t))){if(f.splice(u,1),!(e=o.length&&ge(f)))return B.apply(i,o),i;break}}return(d||a(e,p))(o,t,!g,i,!t||Q.test(e)&&de(t.parentNode)||t),i},n.sortStable=_.split("").sort(E).join("")===_,n.detectDuplicates=!!l,h(),n.sortDetached=ae((function(e){return 1&e.compareDocumentPosition(d.createElement("div"))})),ae((function(e){return e.innerHTML="","#"===e.firstChild.getAttribute("href")}))||ue("type|href|height|width",(function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)})),n.attributes&&ae((function(e){return e.innerHTML="",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")}))||ue("value",(function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue})),ae((function(e){return null==e.getAttribute("disabled")}))||ue(F,(function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null})),ie}(e);d.find=y,d.expr=y.selectors,d.expr[":"]=d.expr.pseudos,d.uniqueSort=d.unique=y.uniqueSort,d.text=y.getText,d.isXMLDoc=y.isXML,d.contains=y.contains;var _=function(e,t,n){for(var r=[],i=void 0!==n;(e=e[t])&&9!==e.nodeType;)if(1===e.nodeType){if(i&&d(e).is(n))break;r.push(e)}return r},w=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},k=d.expr.match.needsContext,j=/^<([\w-]+)\s*\/?>(?:<\/\1>|)$/,x=/^.[^:#\[\.,]*$/;function S(e,t,n){if(d.isFunction(t))return d.grep(e,(function(e,r){return!!t.call(e,r,e)!==n}));if(t.nodeType)return d.grep(e,(function(e){return e===t!==n}));if("string"==typeof t){if(x.test(t))return d.filter(t,e,n);t=d.filter(t,e)}return d.grep(e,(function(e){return a.call(t,e)>-1!==n}))}d.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?d.find.matchesSelector(r,e)?[r]:[]:d.find.matches(e,d.grep(t,(function(e){return 1===e.nodeType})))},d.fn.extend({find:function(e){var t,n=this.length,r=[],i=this;if("string"!=typeof e)return this.pushStack(d(e).filter((function(){for(t=0;t1?d.unique(r):r)).selector=this.selector?this.selector+" "+e:e,r},filter:function(e){return this.pushStack(S(this,e||[],!1))},not:function(e){return this.pushStack(S(this,e||[],!0))},is:function(e){return!!S(this,"string"==typeof e&&k.test(e)?d(e):e||[],!1).length}});var D,E=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/,A;(d.fn.init=function(e,t,n){var i,o;if(!e)return this;if(n=n||D,"string"==typeof e){if(!(i="<"===e[0]&&">"===e[e.length-1]&&e.length>=3?[null,e,null]:E.exec(e))||!i[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(i[1]){if(t=t instanceof d?t[0]:t,d.merge(this,d.parseHTML(i[1],t&&t.nodeType?t.ownerDocument||t:r,!0)),j.test(i[1])&&d.isPlainObject(t))for(i in t)d.isFunction(this[i])?this[i](t[i]):this.attr(i,t[i]);return this}return(o=r.getElementById(i[2]))&&o.parentNode&&(this.length=1,this[0]=o),this.context=r,this.selector=e,this}return e.nodeType?(this.context=this[0]=e,this.length=1,this):d.isFunction(e)?void 0!==n.ready?n.ready(e):e(d):(void 0!==e.selector&&(this.selector=e.selector,this.context=e.context),d.makeArray(e,this))}).prototype=d.fn,D=d(r);var C=/^(?:parents|prev(?:Until|All))/,M={children:!0,contents:!0,next:!0,prev:!0};function O(e,t){for(;(e=e[t])&&1!==e.nodeType;);return e}d.fn.extend({has:function(e){var t=d(e,this),n=t.length;return this.filter((function(){for(var e=0;e-1:1===n.nodeType&&d.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(o.length>1?d.uniqueSort(o):o)},index:function(e){return e?"string"==typeof e?a.call(d(e),this[0]):a.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(d.uniqueSort(d.merge(this.get(),d(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}}),d.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return _(e,"parentNode")},parentsUntil:function(e,t,n){return _(e,"parentNode",n)},next:function(e){return O(e,"nextSibling")},prev:function(e){return O(e,"previousSibling")},nextAll:function(e){return _(e,"nextSibling")},prevAll:function(e){return _(e,"previousSibling")},nextUntil:function(e,t,n){return _(e,"nextSibling",n)},prevUntil:function(e,t,n){return _(e,"previousSibling",n)},siblings:function(e){return w((e.parentNode||{}).firstChild,e)},children:function(e){return w(e.firstChild)},contents:function(e){return e.contentDocument||d.merge([],e.childNodes)}},(function(e,t){d.fn[e]=function(n,r){var i=d.map(this,t,n);return"Until"!==e.slice(-5)&&(r=n),r&&"string"==typeof r&&(i=d.filter(r,i)),this.length>1&&(M[e]||d.uniqueSort(i),C.test(e)&&i.reverse()),this.pushStack(i)}}));var T=/\S+/g,B;function I(e){var t={};return d.each(e.match(T)||[],(function(e,n){t[n]=!0})),t}function R(){r.removeEventListener("DOMContentLoaded",R),e.removeEventListener("load",R),d.ready()}d.Callbacks=function(e){e="string"==typeof e?I(e):d.extend({},e);var t,n,r,i,o=[],s=[],a=-1,u=function(){for(i=e.once,r=t=!0;s.length;a=-1)for(n=s.shift();++a-1;)o.splice(n,1),n<=a&&a--})),this},has:function(e){return e?d.inArray(e,o)>-1:o.length>0},empty:function(){return o&&(o=[]),this},disable:function(){return i=s=[],o=n="",this},disabled:function(){return!o},lock:function(){return i=s=[],n||(o=n=""),this},locked:function(){return!!i},fireWith:function(e,n){return i||(n=[e,(n=n||[]).slice?n.slice():n],s.push(n),t||u()),this},fire:function(){return f.fireWith(this,arguments),this},fired:function(){return!!r}};return f},d.extend({Deferred:function(e){var t=[["resolve","done",d.Callbacks("once memory"),"resolved"],["reject","fail",d.Callbacks("once memory"),"rejected"],["notify","progress",d.Callbacks("memory")]],n="pending",r={state:function(){return n},always:function(){return i.done(arguments).fail(arguments),this},then:function(){var e=arguments;return d.Deferred((function(n){d.each(t,(function(t,o){var s=d.isFunction(e[t])&&e[t];i[o[1]]((function(){var e=s&&s.apply(this,arguments);e&&d.isFunction(e.promise)?e.promise().progress(n.notify).done(n.resolve).fail(n.reject):n[o[0]+"With"](this===r?n.promise():this,s?[e]:arguments)}))})),e=null})).promise()},promise:function(e){return null!=e?d.extend(e,r):r}},i={};return r.pipe=r.then,d.each(t,(function(e,o){var s=o[2],a=o[3];r[o[1]]=s.add,a&&s.add((function(){n=a}),t[1^e][2].disable,t[2][2].lock),i[o[0]]=function(){return i[o[0]+"With"](this===i?r:this,arguments),this},i[o[0]+"With"]=s.fireWith})),r.promise(i),e&&e.call(i,i),i},when:function(e){var t=0,n=i.call(arguments),r=n.length,o=1!==r||e&&d.isFunction(e.promise)?r:0,s=1===o?e:d.Deferred(),a=function(e,t,n){return function(r){t[e]=this,n[e]=arguments.length>1?i.call(arguments):r,n===u?s.notifyWith(t,n):--o||s.resolveWith(t,n)}},u,f,c;if(r>1)for(u=new Array(r),f=new Array(r),c=new Array(r);t0||(B.resolveWith(r,[d]),d.fn.triggerHandler&&(d(r).triggerHandler("ready"),d(r).off("ready"))))}}),d.ready.promise=function(t){return B||(B=d.Deferred(),"complete"===r.readyState||"loading"!==r.readyState&&!r.documentElement.doScroll?e.setTimeout(d.ready):(r.addEventListener("DOMContentLoaded",R),e.addEventListener("load",R))),B.promise(t)},d.ready.promise();var F=function(e,t,n,r,i,o,s){var a=0,u=e.length,f=null==n;if("object"===d.type(n))for(a in i=!0,n)F(e,t,a,n[a],!0,o,s);else if(void 0!==r&&(i=!0,d.isFunction(r)||(s=!0),f&&(s?(t.call(e,r),t=null):(f=t,t=function(e,t,n){return f.call(d(e),n)})),t))for(;a-1&&void 0!==n&&z.set(this,e,t)}))}),null,t,arguments.length>1,null,!0)},removeData:function(e){return this.each((function(){z.remove(this,e)}))}}),d.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=L.get(e,t),n&&(!r||d.isArray(n)?r=L.access(e,t,d.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=d.queue(e,t),r=n.length,i=n.shift(),o=d._queueHooks(e,t),s=function(){d.dequeue(e,t)};"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,s,o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return L.get(e,n)||L.access(e,n,{empty:d.Callbacks("once memory").add((function(){L.remove(e,[t+"queue",n])}))})}}),d.fn.extend({queue:function(e,t){var n=2;return"string"!=typeof e&&(t=e,e="fx",n--),arguments.length",""],thead:[1,"","
"],col:[2,"","
"],tr:[2,"","
"],td:[3,"","
"],_default:[0,"",""]};function Q(e,t){var n=void 0!==e.getElementsByTagName?e.getElementsByTagName(t||"*"):void 0!==e.querySelectorAll?e.querySelectorAll(t||"*"):[];return void 0===t||t&&d.nodeName(e,t)?d.merge([e],n):n}function ee(e,t){for(var n=0,r=e.length;n-1)i&&i.push(o);else if(f=d.contains(o.ownerDocument,o),s=Q(l.appendChild(o),"script"),f&&ee(s),n)for(c=0;o=s[c++];)Z.test(o.type||"")&&n.push(o);return l}re=r.createDocumentFragment().appendChild(r.createElement("div")),(ie=r.createElement("input")).setAttribute("type","radio"),ie.setAttribute("checked","checked"),ie.setAttribute("name","t"),re.appendChild(ie),l.checkClone=re.cloneNode(!0).cloneNode(!0).lastChild.checked,re.innerHTML="",l.noCloneChecked=!!re.cloneNode(!0).lastChild.defaultValue;var se=/^key/,ae=/^(?:mouse|pointer|contextmenu|drag|drop)|click/,ue=/^([^.]*)(?:\.(.+)|)/;function fe(){return!0}function ce(){return!1}function le(){try{return r.activeElement}catch(e){}}function he(e,t,n,r,i,o){var s,a;if("object"==typeof t){for(a in"string"!=typeof n&&(r=r||n,n=void 0),t)he(e,a,n,r,t[a],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=ce;else if(!i)return e;return 1===o&&(s=i,(i=function(e){return d().off(e),s.apply(this,arguments)}).guid=s.guid||(s.guid=d.guid++)),e.each((function(){d.event.add(this,t,i,r,n)}))}d.event={global:{},add:function(e,t,n,r,i){var o,s,a,u,f,c,l,h,p,g,b,m=L.get(e);if(m)for(n.handler&&(n=(o=n).handler,i=o.selector),n.guid||(n.guid=d.guid++),(u=m.events)||(u=m.events={}),(s=m.handle)||(s=m.handle=function(t){return void 0!==d&&d.event.triggered!==t.type?d.event.dispatch.apply(e,arguments):void 0}),f=(t=(t||"").match(T)||[""]).length;f--;)p=b=(a=ue.exec(t[f])||[])[1],g=(a[2]||"").split(".").sort(),p&&(l=d.event.special[p]||{},p=(i?l.delegateType:l.bindType)||p,l=d.event.special[p]||{},c=d.extend({type:p,origType:b,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&d.expr.match.needsContext.test(i),namespace:g.join(".")},o),(h=u[p])||((h=u[p]=[]).delegateCount=0,l.setup&&!1!==l.setup.call(e,r,g,s)||e.addEventListener&&e.addEventListener(p,s)),l.add&&(l.add.call(e,c),c.handler.guid||(c.handler.guid=n.guid)),i?h.splice(h.delegateCount++,0,c):h.push(c),d.event.global[p]=!0)},remove:function(e,t,n,r,i){var o,s,a,u,f,c,l,h,p,g,b,m=L.hasData(e)&&L.get(e);if(m&&(u=m.events)){for(f=(t=(t||"").match(T)||[""]).length;f--;)if(p=b=(a=ue.exec(t[f])||[])[1],g=(a[2]||"").split(".").sort(),p){for(l=d.event.special[p]||{},h=u[p=(r?l.delegateType:l.bindType)||p]||[],a=a[2]&&new RegExp("(^|\\.)"+g.join("\\.(?:.*\\.|)")+"(\\.|$)"),s=o=h.length;o--;)c=h[o],!i&&b!==c.origType||n&&n.guid!==c.guid||a&&!a.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(h.splice(o,1),c.selector&&h.delegateCount--,l.remove&&l.remove.call(e,c));s&&!h.length&&(l.teardown&&!1!==l.teardown.call(e,g,m.handle)||d.removeEvent(e,p,m.handle),delete u[p])}else for(p in u)d.event.remove(e,p+t[f],n,r,!0);d.isEmptyObject(u)&&L.remove(e,"handle events")}},dispatch:function(e){e=d.event.fix(e);var t,n,r,o,s,a=[],u=i.call(arguments),f=(L.get(this,"events")||{})[e.type]||[],c=d.event.special[e.type]||{};if(u[0]=e,e.delegateTarget=this,!c.preDispatch||!1!==c.preDispatch.call(this,e)){for(a=d.event.handlers.call(this,e,f),t=0;(o=a[t++])&&!e.isPropagationStopped();)for(e.currentTarget=o.elem,n=0;(s=o.handlers[n++])&&!e.isImmediatePropagationStopped();)e.rnamespace&&!e.rnamespace.test(s.namespace)||(e.handleObj=s,e.data=s.data,void 0!==(r=((d.event.special[s.origType]||{}).handle||s.handler).apply(o.elem,u))&&!1===(e.result=r)&&(e.preventDefault(),e.stopPropagation()));return c.postDispatch&&c.postDispatch.call(this,e),e.result}},handlers:function(e,t){var n,r,i,o,s=[],a=t.delegateCount,u=e.target;if(a&&u.nodeType&&("click"!==e.type||isNaN(e.button)||e.button<1))for(;u!==this;u=u.parentNode||this)if(1===u.nodeType&&(!0!==u.disabled||"click"!==e.type)){for(r=[],n=0;n-1:d.find(i,this,null,[u]).length),r[i]&&r.push(o);r.length&&s.push({elem:u,handlers:r})}return a]*)\/>/gi,pe=/\s*$/g;function ve(e,t){return d.nodeName(e,"table")&&d.nodeName(11!==t.nodeType?t:t.firstChild,"tr")?e.getElementsByTagName("tbody")[0]||e.appendChild(e.ownerDocument.createElement("tbody")):e}function ye(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function _e(e){var t=be.exec(e.type);return t?e.type=t[1]:e.removeAttribute("type"),e}function we(e,t){var n,r,i,o,s,a,u,f;if(1===t.nodeType){if(L.hasData(e)&&(o=L.access(e),s=L.set(t,o),f=o.events))for(i in delete s.handle,s.events={},f)for(n=0,r=f[i].length;n1&&"string"==typeof b&&!l.checkClone&&ge.test(b))return e.each((function(i){var o=e.eq(i);m&&(t[0]=b.call(this,i,o.html())),je(o,t,n,r)}));if(p&&(s=(i=oe(t,e[0].ownerDocument,!1,e,r)).firstChild,1===i.childNodes.length&&(i=s),s||r)){for(u=(a=d.map(Q(i,"script"),ye)).length;h")},clone:function(e,t,n){var r,i,o,s,a=e.cloneNode(!0),u=d.contains(e.ownerDocument,e);if(!(l.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||d.isXMLDoc(e)))for(s=Q(a),r=0,i=(o=Q(e)).length;r0&&ee(s,!u&&Q(e,"script")),a},cleanData:function(e){for(var t,n,r,i=d.event.special,o=0;void 0!==(n=e[o]);o++)if(P(n)){if(t=n[L.expando]){if(t.events)for(r in t.events)i[r]?d.event.remove(n,r):d.removeEvent(n,r,t.handle);n[L.expando]=void 0}n[z.expando]&&(n[z.expando]=void 0)}}}),d.fn.extend({domManip:je,detach:function(e){return xe(this,e,!0)},remove:function(e){return xe(this,e)},text:function(e){return F(this,(function(e){return void 0===e?d.text(this):this.empty().each((function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)}))}),null,e,arguments.length)},append:function(){return je(this,arguments,(function(e){var t;1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||ve(this,e).appendChild(e)}))},prepend:function(){return je(this,arguments,(function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=ve(this,e);t.insertBefore(e,t.firstChild)}}))},before:function(){return je(this,arguments,(function(e){this.parentNode&&this.parentNode.insertBefore(e,this)}))},after:function(){return je(this,arguments,(function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)}))},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(d.cleanData(Q(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map((function(){return d.clone(this,e,t)}))},html:function(e){return F(this,(function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!pe.test(e)&&!J[(X.exec(e)||["",""])[1].toLowerCase()]){e=d.htmlPrefilter(e);try{for(;n")).appendTo(t.documentElement))[0].contentDocument).write(),t.close(),n=Ee(e,t),Se.detach()),De[e]=n),n}var Ce=/^margin/,Me=new RegExp("^("+H+")(?!px)[a-z%]+$","i"),Oe=function(t){var n=t.ownerDocument.defaultView;return n&&n.opener||(n=e),n.getComputedStyle(t)},Te=function(e,t,n,r){var i,o,s={};for(o in t)s[o]=e.style[o],e.style[o]=t[o];for(o in i=n.apply(e,r||[]),t)e.style[o]=s[o];return i},Be=r.documentElement;function Ie(e,t,n){var r,i,o,s,a=e.style;return""!==(s=(n=n||Oe(e))?n.getPropertyValue(t)||n[t]:void 0)&&void 0!==s||d.contains(e.ownerDocument,e)||(s=d.style(e,t)),n&&!l.pixelMarginRight()&&Me.test(s)&&Ce.test(t)&&(r=a.width,i=a.minWidth,o=a.maxWidth,a.minWidth=a.maxWidth=a.width=s,s=n.width,a.width=r,a.minWidth=i,a.maxWidth=o),void 0!==s?s+"":s}function Re(e,t){return{get:function(){if(!e())return(this.get=t).apply(this,arguments);delete this.get}}}!function(){var t,n,i,o,s=r.createElement("div"),a=r.createElement("div");function u(){a.style.cssText="-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;position:relative;display:block;margin:auto;border:1px;padding:1px;top:1%;width:50%",a.innerHTML="",Be.appendChild(s);var r=e.getComputedStyle(a);t="1%"!==r.top,o="2px"===r.marginLeft,n="4px"===r.width,a.style.marginRight="50%",i="4px"===r.marginRight,Be.removeChild(s)}a.style&&(a.style.backgroundClip="content-box",a.cloneNode(!0).style.backgroundClip="",l.clearCloneStyle="content-box"===a.style.backgroundClip,s.style.cssText="border:0;width:8px;height:0;top:0;left:-9999px;padding:0;margin-top:1px;position:absolute",s.appendChild(a),d.extend(l,{pixelPosition:function(){return u(),t},boxSizingReliable:function(){return null==n&&u(),n},pixelMarginRight:function(){return null==n&&u(),i},reliableMarginLeft:function(){return null==n&&u(),o},reliableMarginRight:function(){var t,n=a.appendChild(r.createElement("div"));return n.style.cssText=a.style.cssText="-webkit-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:0",n.style.marginRight=n.style.width="0",a.style.width="1px",Be.appendChild(s),t=!parseFloat(e.getComputedStyle(n).marginRight),Be.removeChild(s),a.removeChild(n),t}}))}();var Fe=/^(none|table(?!-c[ea]).+)/,Pe={position:"absolute",visibility:"hidden",display:"block"},Ne={letterSpacing:"0",fontWeight:"400"},Le=["Webkit","O","Moz","ms"],ze=r.createElement("div").style;function Ue(e){if(e in ze)return e;for(var t=e[0].toUpperCase()+e.slice(1),n=Le.length;n--;)if((e=Le[n]+t)in ze)return e}function qe(e,t,n){var r=W.exec(t);return r?Math.max(0,r[2]-(n||0))+(r[3]||"px"):t}function $e(e,t,n,r,i){for(var o=n===(r?"border":"content")?4:"width"===t?1:0,s=0;o<4;o+=2)"margin"===n&&(s+=d.css(e,n+Y[o],!0,i)),r?("content"===n&&(s-=d.css(e,"padding"+Y[o],!0,i)),"margin"!==n&&(s-=d.css(e,"border"+Y[o]+"Width",!0,i))):(s+=d.css(e,"padding"+Y[o],!0,i),"padding"!==n&&(s+=d.css(e,"border"+Y[o]+"Width",!0,i)));return s}function He(e,t,n){var r=!0,i="width"===t?e.offsetWidth:e.offsetHeight,o=Oe(e),s="border-box"===d.css(e,"boxSizing",!1,o);if(i<=0||null==i){if(((i=Ie(e,t,o))<0||null==i)&&(i=e.style[t]),Me.test(i))return i;r=s&&(l.boxSizingReliable()||i===e.style[t]),i=parseFloat(i)||0}return i+$e(e,t,n||(s?"border":"content"),r,o)+"px"}function We(e,t){for(var n,r,i,o=[],s=0,a=e.length;s1)},show:function(){return We(this,!0)},hide:function(){return We(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each((function(){V(this)?d(this).show():d(this).hide()}))}}),d.Tween=Ye,Ye.prototype={constructor:Ye,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||d.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(d.cssNumber[n]?"":"px")},cur:function(){var e=Ye.propHooks[this.prop];return e&&e.get?e.get(this):Ye.propHooks._default.get(this)},run:function(e){var t,n=Ye.propHooks[this.prop];return this.options.duration?this.pos=t=d.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):Ye.propHooks._default.set(this),this}},Ye.prototype.init.prototype=Ye.prototype,Ye.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=d.css(e.elem,e.prop,""))&&"auto"!==t?t:0},set:function(e){d.fx.step[e.prop]?d.fx.step[e.prop](e):1!==e.elem.nodeType||null==e.elem.style[d.cssProps[e.prop]]&&!d.cssHooks[e.prop]?e.elem[e.prop]=e.now:d.style(e.elem,e.prop,e.now+e.unit)}}},Ye.propHooks.scrollTop=Ye.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},d.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:"swing"},d.fx=Ye.prototype.init,d.fx.step={};var Ve,Ke,Ge=/^(?:toggle|show|hide)$/,Xe=/queueHooks$/;function Ze(){return e.setTimeout((function(){Ve=void 0})),Ve=d.now()}function Je(e,t){var n,r=0,i={height:e};for(t=t?1:0;r<4;r+=2-t)i["margin"+(n=Y[r])]=i["padding"+n]=e;return t&&(i.opacity=i.width=e),i}function Qe(e,t,n){for(var r,i=(nt.tweeners[t]||[]).concat(nt.tweeners["*"]),o=0,s=i.length;o1)},removeAttr:function(e){return this.each((function(){d.removeAttr(this,e)}))}}),d.extend({attr:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return void 0===e.getAttribute?d.prop(e,t,n):(1===o&&d.isXMLDoc(e)||(t=t.toLowerCase(),i=d.attrHooks[t]||(d.expr.match.bool.test(t)?rt:void 0)),void 0!==n?null===n?void d.removeAttr(e,t):i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:(e.setAttribute(t,n+""),n):i&&"get"in i&&null!==(r=i.get(e,t))?r:null==(r=d.find.attr(e,t))?void 0:r)},attrHooks:{type:{set:function(e,t){if(!l.radioValue&&"radio"===t&&d.nodeName(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,r,i=0,o=t&&t.match(T);if(o&&1===e.nodeType)for(;n=o[i++];)r=d.propFix[n]||n,d.expr.match.bool.test(n)&&(e[r]=!1),e.removeAttribute(n)}}),rt={set:function(e,t,n){return!1===t?d.removeAttr(e,n):e.setAttribute(n,n),n}},d.each(d.expr.match.bool.source.match(/\w+/g),(function(e,t){var n=it[t]||d.find.attr;it[t]=function(e,t,r){var i,o;return r||(o=it[t],it[t]=i,i=null!=n(e,t,r)?t.toLowerCase():null,it[t]=o),i}}));var ot=/^(?:input|select|textarea|button)$/i,st=/^(?:a|area)$/i;d.fn.extend({prop:function(e,t){return F(this,d.prop,e,t,arguments.length>1)},removeProp:function(e){return this.each((function(){delete this[d.propFix[e]||e]}))}}),d.extend({prop:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return 1===o&&d.isXMLDoc(e)||(t=d.propFix[t]||t,i=d.propHooks[t]),void 0!==n?i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){var t=d.find.attr(e,"tabindex");return t?parseInt(t,10):ot.test(e.nodeName)||st.test(e.nodeName)&&e.href?0:-1}}},propFix:{for:"htmlFor",class:"className"}}),l.optSelected||(d.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),d.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],(function(){d.propFix[this.toLowerCase()]=this}));var at=/[\t\r\n\f]/g;function ut(e){return e.getAttribute&&e.getAttribute("class")||""}d.fn.extend({addClass:function(e){var t,n,r,i,o,s,a,u=0;if(d.isFunction(e))return this.each((function(t){d(this).addClass(e.call(this,t,ut(this)))}));if("string"==typeof e&&e)for(t=e.match(T)||[];n=this[u++];)if(i=ut(n),r=1===n.nodeType&&(" "+i+" ").replace(at," ")){for(s=0;o=t[s++];)r.indexOf(" "+o+" ")<0&&(r+=o+" ");i!==(a=d.trim(r))&&n.setAttribute("class",a)}return this},removeClass:function(e){var t,n,r,i,o,s,a,u=0;if(d.isFunction(e))return this.each((function(t){d(this).removeClass(e.call(this,t,ut(this)))}));if(!arguments.length)return this.attr("class","");if("string"==typeof e&&e)for(t=e.match(T)||[];n=this[u++];)if(i=ut(n),r=1===n.nodeType&&(" "+i+" ").replace(at," ")){for(s=0;o=t[s++];)for(;r.indexOf(" "+o+" ")>-1;)r=r.replace(" "+o+" "," ");i!==(a=d.trim(r))&&n.setAttribute("class",a)}return this},toggleClass:function(e,t){var n=typeof e;return"boolean"==typeof t&&"string"===n?t?this.addClass(e):this.removeClass(e):d.isFunction(e)?this.each((function(n){d(this).toggleClass(e.call(this,n,ut(this),t),t)})):this.each((function(){var t,r,i,o;if("string"===n)for(r=0,i=d(this),o=e.match(T)||[];t=o[r++];)i.hasClass(t)?i.removeClass(t):i.addClass(t);else void 0!==e&&"boolean"!==n||((t=ut(this))&&L.set(this,"__className__",t),this.setAttribute&&this.setAttribute("class",t||!1===e?"":L.get(this,"__className__")||""))}))},hasClass:function(e){var t,n,r=0;for(t=" "+e+" ";n=this[r++];)if(1===n.nodeType&&(" "+ut(n)+" ").replace(at," ").indexOf(t)>-1)return!0;return!1}});var ft=/\r/g,ct=/[\x20\t\r\n\f]+/g;d.fn.extend({val:function(e){var t,n,r,i=this[0];return arguments.length?(r=d.isFunction(e),this.each((function(n){var i;1===this.nodeType&&(null==(i=r?e.call(this,n,d(this).val()):e)?i="":"number"==typeof i?i+="":d.isArray(i)&&(i=d.map(i,(function(e){return null==e?"":e+""}))),(t=d.valHooks[this.type]||d.valHooks[this.nodeName.toLowerCase()])&&"set"in t&&void 0!==t.set(this,i,"value")||(this.value=i))}))):i?(t=d.valHooks[i.type]||d.valHooks[i.nodeName.toLowerCase()])&&"get"in t&&void 0!==(n=t.get(i,"value"))?n:"string"==typeof(n=i.value)?n.replace(ft,""):null==n?"":n:void 0}}),d.extend({valHooks:{option:{get:function(e){var t=d.find.attr(e,"value");return null!=t?t:d.trim(d.text(e)).replace(ct," ")}},select:{get:function(e){for(var t,n,r=e.options,i=e.selectedIndex,o="select-one"===e.type||i<0,s=o?null:[],a=o?i+1:r.length,u=i<0?a:o?i:0;u-1)&&(n=!0);return n||(e.selectedIndex=-1),o}}}}),d.each(["radio","checkbox"],(function(){d.valHooks[this]={set:function(e,t){if(d.isArray(t))return e.checked=d.inArray(d(e).val(),t)>-1}},l.checkOn||(d.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})}));var lt=/^(?:focusinfocus|focusoutblur)$/;d.extend(d.event,{trigger:function(t,n,i,o){var s,a,u,f,l,h,p,g=[i||r],b=c.call(t,"type")?t.type:t,m=c.call(t,"namespace")?t.namespace.split("."):[];if(a=u=i=i||r,3!==i.nodeType&&8!==i.nodeType&&!lt.test(b+d.event.triggered)&&(b.indexOf(".")>-1&&(m=b.split("."),b=m.shift(),m.sort()),l=b.indexOf(":")<0&&"on"+b,(t=t[d.expando]?t:new d.Event(b,"object"==typeof t&&t)).isTrigger=o?2:3,t.namespace=m.join("."),t.rnamespace=t.namespace?new RegExp("(^|\\.)"+m.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,t.result=void 0,t.target||(t.target=i),n=null==n?[t]:d.makeArray(n,[t]),p=d.event.special[b]||{},o||!p.trigger||!1!==p.trigger.apply(i,n))){if(!o&&!p.noBubble&&!d.isWindow(i)){for(f=p.delegateType||b,lt.test(f+b)||(a=a.parentNode);a;a=a.parentNode)g.push(a),u=a;u===(i.ownerDocument||r)&&g.push(u.defaultView||u.parentWindow||e)}for(s=0;(a=g[s++])&&!t.isPropagationStopped();)t.type=s>1?f:p.bindType||b,(h=(L.get(a,"events")||{})[t.type]&&L.get(a,"handle"))&&h.apply(a,n),(h=l&&a[l])&&h.apply&&P(a)&&(t.result=h.apply(a,n),!1===t.result&&t.preventDefault());return t.type=b,o||t.isDefaultPrevented()||p._default&&!1!==p._default.apply(g.pop(),n)||!P(i)||l&&d.isFunction(i[b])&&!d.isWindow(i)&&((u=i[l])&&(i[l]=null),d.event.triggered=b,i[b](),d.event.triggered=void 0,u&&(i[l]=u)),t.result}},simulate:function(e,t,n){var r=d.extend(new d.Event,n,{type:e,isSimulated:!0});d.event.trigger(r,null,t)}}),d.fn.extend({trigger:function(e,t){return this.each((function(){d.event.trigger(e,t,this)}))},triggerHandler:function(e,t){var n=this[0];if(n)return d.event.trigger(e,t,n,!0)}}),d.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error contextmenu".split(" "),(function(e,t){d.fn[t]=function(e,n){return arguments.length>0?this.on(t,null,e,n):this.trigger(t)}})),d.fn.extend({hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)}}),l.focusin="onfocusin"in e,l.focusin||d.each({focus:"focusin",blur:"focusout"},(function(e,t){var n=function(e){d.event.simulate(t,e.target,d.event.fix(e))};d.event.special[t]={setup:function(){var r=this.ownerDocument||this,i=L.access(r,t);i||r.addEventListener(e,n,!0),L.access(r,t,(i||0)+1)},teardown:function(){var r=this.ownerDocument||this,i=L.access(r,t)-1;i?L.access(r,t,i):(r.removeEventListener(e,n,!0),L.remove(r,t))}}}));var ht=e.location,dt=d.now(),pt=/\?/;d.parseJSON=function(e){return JSON.parse(e+"")},d.parseXML=function(t){var n;if(!t||"string"!=typeof t)return null;try{n=(new e.DOMParser).parseFromString(t,"text/xml")}catch(r){n=void 0}return n&&!n.getElementsByTagName("parsererror").length||d.error("Invalid XML: "+t),n};var gt=/#.*$/,bt=/([?&])_=[^&]*/,mt=/^(.*?):[ \t]*([^\r\n]*)$/gm,vt=/^(?:about|app|app-storage|.+-extension|file|res|widget):$/,yt=/^(?:GET|HEAD)$/,_t=/^\/\//,wt={},kt={},jt="*/".concat("*"),xt=r.createElement("a");function St(e){return function(t,n){"string"!=typeof t&&(n=t,t="*");var r,i=0,o=t.toLowerCase().match(T)||[];if(d.isFunction(n))for(;r=o[i++];)"+"===r[0]?(r=r.slice(1)||"*",(e[r]=e[r]||[]).unshift(n)):(e[r]=e[r]||[]).push(n)}}function Dt(e,t,n,r){var i={},o=e===kt;function s(a){var u;return i[a]=!0,d.each(e[a]||[],(function(e,a){var f=a(t,n,r);return"string"!=typeof f||o||i[f]?o?!(u=f):void 0:(t.dataTypes.unshift(f),s(f),!1)})),u}return s(t.dataTypes[0])||!i["*"]&&s("*")}function Et(e,t){var n,r,i=d.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&d.extend(!0,e,r),e}function At(e,t,n){for(var r,i,o,s,a=e.contents,u=e.dataTypes;"*"===u[0];)u.shift(),void 0===r&&(r=e.mimeType||t.getResponseHeader("Content-Type"));if(r)for(i in a)if(a[i]&&a[i].test(r)){u.unshift(i);break}if(u[0]in n)o=u[0];else{for(i in n){if(!u[0]||e.converters[i+" "+u[0]]){o=i;break}s||(s=i)}o=o||s}if(o)return o!==u[0]&&u.unshift(o),n[o]}function Ct(e,t,n,r){var i,o,s,a,u,f={},c=e.dataTypes.slice();if(c[1])for(s in e.converters)f[s.toLowerCase()]=e.converters[s];for(o=c.shift();o;)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if("*"===o)o=u;else if("*"!==u&&u!==o){if(!(s=f[u+" "+o]||f["* "+o]))for(i in f)if((a=i.split(" "))[1]===o&&(s=f[u+" "+a[0]]||f["* "+a[0]])){!0===s?s=f[i]:!0!==f[i]&&(o=a[0],c.unshift(a[1]));break}if(!0!==s)if(s&&e.throws)t=s(t);else try{t=s(t)}catch(l){return{state:"parsererror",error:s?l:"No conversion from "+u+" to "+o}}}return{state:"success",data:t}}xt.href=ht.href,d.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:ht.href,type:"GET",isLocal:vt.test(ht.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":jt,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":d.parseJSON,"text xml":d.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?Et(Et(e,d.ajaxSettings),t):Et(d.ajaxSettings,e)},ajaxPrefilter:St(wt),ajaxTransport:St(kt),ajax:function(t,n){"object"==typeof t&&(n=t,t=void 0),n=n||{};var i,o,s,a,u,f,c,l,h=d.ajaxSetup({},n),p=h.context||h,g=h.context&&(p.nodeType||p.jquery)?d(p):d.event,b=d.Deferred(),m=d.Callbacks("once memory"),v=h.statusCode||{},y={},_={},w=0,k="canceled",j={readyState:0,getResponseHeader:function(e){var t;if(2===w){if(!a)for(a={};t=mt.exec(s);)a[t[1].toLowerCase()]=t[2];t=a[e.toLowerCase()]}return null==t?null:t},getAllResponseHeaders:function(){return 2===w?s:null},setRequestHeader:function(e,t){var n=e.toLowerCase();return w||(e=_[n]=_[n]||e,y[e]=t),this},overrideMimeType:function(e){return w||(h.mimeType=e),this},statusCode:function(e){var t;if(e)if(w<2)for(t in e)v[t]=[v[t],e[t]];else j.always(e[j.status]);return this},abort:function(e){var t=e||k;return i&&i.abort(t),x(0,t),this}};if(b.promise(j).complete=m.add,j.success=j.done,j.error=j.fail,h.url=((t||h.url||ht.href)+"").replace(gt,"").replace(_t,ht.protocol+"//"),h.type=n.method||n.type||h.method||h.type,h.dataTypes=d.trim(h.dataType||"*").toLowerCase().match(T)||[""],null==h.crossDomain){f=r.createElement("a");try{f.href=h.url,f.href=f.href,h.crossDomain=xt.protocol+"//"+xt.host!=f.protocol+"//"+f.host}catch(S){h.crossDomain=!0}}if(h.data&&h.processData&&"string"!=typeof h.data&&(h.data=d.param(h.data,h.traditional)),Dt(wt,h,n,j),2===w)return j;for(l in(c=d.event&&h.global)&&0==d.active++&&d.event.trigger("ajaxStart"),h.type=h.type.toUpperCase(),h.hasContent=!yt.test(h.type),o=h.url,h.hasContent||(h.data&&(o=h.url+=(pt.test(o)?"&":"?")+h.data,delete h.data),!1===h.cache&&(h.url=bt.test(o)?o.replace(bt,"$1_="+dt++):o+(pt.test(o)?"&":"?")+"_="+dt++)),h.ifModified&&(d.lastModified[o]&&j.setRequestHeader("If-Modified-Since",d.lastModified[o]),d.etag[o]&&j.setRequestHeader("If-None-Match",d.etag[o])),(h.data&&h.hasContent&&!1!==h.contentType||n.contentType)&&j.setRequestHeader("Content-Type",h.contentType),j.setRequestHeader("Accept",h.dataTypes[0]&&h.accepts[h.dataTypes[0]]?h.accepts[h.dataTypes[0]]+("*"!==h.dataTypes[0]?", "+jt+"; q=0.01":""):h.accepts["*"]),h.headers)j.setRequestHeader(l,h.headers[l]);if(h.beforeSend&&(!1===h.beforeSend.call(p,j,h)||2===w))return j.abort();for(l in k="abort",{success:1,error:1,complete:1})j[l](h[l]);if(i=Dt(kt,h,n,j)){if(j.readyState=1,c&&g.trigger("ajaxSend",[j,h]),2===w)return j;h.async&&h.timeout>0&&(u=e.setTimeout((function(){j.abort("timeout")}),h.timeout));try{w=1,i.send(y,x)}catch(S){if(!(w<2))throw S;x(-1,S)}}else x(-1,"No Transport");function x(t,n,r,a){var f,l,y,_,k,x=n;2!==w&&(w=2,u&&e.clearTimeout(u),i=void 0,s=a||"",j.readyState=t>0?4:0,f=t>=200&&t<300||304===t,r&&(_=At(h,j,r)),_=Ct(h,_,j,f),f?(h.ifModified&&((k=j.getResponseHeader("Last-Modified"))&&(d.lastModified[o]=k),(k=j.getResponseHeader("etag"))&&(d.etag[o]=k)),204===t||"HEAD"===h.type?x="nocontent":304===t?x="notmodified":(x=_.state,l=_.data,f=!(y=_.error))):(y=x,!t&&x||(x="error",t<0&&(t=0))),j.status=t,j.statusText=(n||x)+"",f?b.resolveWith(p,[l,x,j]):b.rejectWith(p,[j,x,y]),j.statusCode(v),v=void 0,c&&g.trigger(f?"ajaxSuccess":"ajaxError",[j,h,f?l:y]),m.fireWith(p,[j,x]),c&&(g.trigger("ajaxComplete",[j,h]),--d.active||d.event.trigger("ajaxStop")))}return j},getJSON:function(e,t,n){return d.get(e,t,n,"json")},getScript:function(e,t){return d.get(e,void 0,t,"script")}}),d.each(["get","post"],(function(e,t){d[t]=function(e,n,r,i){return d.isFunction(n)&&(i=i||r,r=n,n=void 0),d.ajax(d.extend({url:e,type:t,dataType:i,data:n,success:r},d.isPlainObject(e)&&e))}})),d._evalUrl=function(e){return d.ajax({url:e,type:"GET",dataType:"script",async:!1,global:!1,throws:!0})},d.fn.extend({wrapAll:function(e){var t;return d.isFunction(e)?this.each((function(t){d(this).wrapAll(e.call(this,t))})):(this[0]&&(t=d(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map((function(){for(var e=this;e.firstElementChild;)e=e.firstElementChild;return e})).append(this)),this)},wrapInner:function(e){return d.isFunction(e)?this.each((function(t){d(this).wrapInner(e.call(this,t))})):this.each((function(){var t=d(this),n=t.contents();n.length?n.wrapAll(e):t.append(e)}))},wrap:function(e){var t=d.isFunction(e);return this.each((function(n){d(this).wrapAll(t?e.call(this,n):e)}))},unwrap:function(){return this.parent().each((function(){d.nodeName(this,"body")||d(this).replaceWith(this.childNodes)})).end()}}),d.expr.filters.hidden=function(e){return!d.expr.filters.visible(e)},d.expr.filters.visible=function(e){return e.offsetWidth>0||e.offsetHeight>0||e.getClientRects().length>0};var Mt=/%20/g,Ot=/\[\]$/,Tt=/\r?\n/g,Bt=/^(?:submit|button|image|reset|file)$/i,It=/^(?:input|select|textarea|keygen)/i;function Rt(e,t,n,r){var i;if(d.isArray(t))d.each(t,(function(t,i){n||Ot.test(e)?r(e,i):Rt(e+"["+("object"==typeof i&&null!=i?t:"")+"]",i,n,r)}));else if(n||"object"!==d.type(t))r(e,t);else for(i in t)Rt(e+"["+i+"]",t[i],n,r)}d.param=function(e,t){var n,r=[],i=function(e,t){t=d.isFunction(t)?t():null==t?"":t,r[r.length]=encodeURIComponent(e)+"="+encodeURIComponent(t)};if(void 0===t&&(t=d.ajaxSettings&&d.ajaxSettings.traditional),d.isArray(e)||e.jquery&&!d.isPlainObject(e))d.each(e,(function(){i(this.name,this.value)}));else for(n in e)Rt(n,e[n],t,i);return r.join("&").replace(Mt,"+")},d.fn.extend({serialize:function(){return d.param(this.serializeArray())},serializeArray:function(){return this.map((function(){var e=d.prop(this,"elements");return e?d.makeArray(e):this})).filter((function(){var e=this.type;return this.name&&!d(this).is(":disabled")&&It.test(this.nodeName)&&!Bt.test(e)&&(this.checked||!G.test(e))})).map((function(e,t){var n=d(this).val();return null==n?null:d.isArray(n)?d.map(n,(function(e){return{name:t.name,value:e.replace(Tt,"\r\n")}})):{name:t.name,value:n.replace(Tt,"\r\n")}})).get()}}),d.ajaxSettings.xhr=function(){try{return new e.XMLHttpRequest}catch(t){}};var Ft={0:200,1223:204},Pt=d.ajaxSettings.xhr();l.cors=!!Pt&&"withCredentials"in Pt,l.ajax=Pt=!!Pt,d.ajaxTransport((function(t){var n,r;if(l.cors||Pt&&!t.crossDomain)return{send:function(i,o){var s,a=t.xhr();if(a.open(t.type,t.url,t.async,t.username,t.password),t.xhrFields)for(s in t.xhrFields)a[s]=t.xhrFields[s];for(s in t.mimeType&&a.overrideMimeType&&a.overrideMimeType(t.mimeType),t.crossDomain||i["X-Requested-With"]||(i["X-Requested-With"]="XMLHttpRequest"),i)a.setRequestHeader(s,i[s]);n=function(e){return function(){n&&(n=r=a.onload=a.onerror=a.onabort=a.onreadystatechange=null,"abort"===e?a.abort():"error"===e?"number"!=typeof a.status?o(0,"error"):o(a.status,a.statusText):o(Ft[a.status]||a.status,a.statusText,"text"!==(a.responseType||"text")||"string"!=typeof a.responseText?{binary:a.response}:{text:a.responseText},a.getAllResponseHeaders()))}},a.onload=n(),r=a.onerror=n("error"),void 0!==a.onabort?a.onabort=r:a.onreadystatechange=function(){4===a.readyState&&e.setTimeout((function(){n&&r()}))},n=n("abort");try{a.send(t.hasContent&&t.data||null)}catch(u){if(n)throw u}},abort:function(){n&&n()}}})),d.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return d.globalEval(e),e}}}),d.ajaxPrefilter("script",(function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")})),d.ajaxTransport("script",(function(e){var t,n;if(e.crossDomain)return{send:function(i,o){t=d("