Skip to content

Commit

Permalink
4.4.0
Browse files Browse the repository at this point in the history
  • Loading branch information
mikemitchel committed Aug 21, 2019
1 parent ff99b7d commit 4d04968
Show file tree
Hide file tree
Showing 3 changed files with 1,159 additions and 0 deletions.
335 changes: 335 additions & 0 deletions dist/amd/can-map-define.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,335 @@
/*can-map-define@4.3.9#can-map-define*/
define([
'require',
'exports',
'module',
'can-log/dev',
'can-assign',
'can-event-queue/map',
'can-queues',
'can-map/map-helpers',
'can-map',
'can-compute',
'can-reflect',
'can-observation-recorder',
'can-simple-observable/resolver',
'can-symbol',
'can-list'
], function (require, exports, module) {
'use strict';
var dev = require('can-log/dev');
var extend = require('can-assign');
var mapEventsMixin = require('can-event-queue/map');
var queues = require('can-queues');
var mapHelpers = require('can-map/map-helpers');
var CanMap = require('can-map');
var compute = require('can-compute');
var canReflect = require('can-reflect');
var ObservationRecorder = require('can-observation-recorder');
var Resolver = require('can-simple-observable/resolver');
var canSymbol = require('can-symbol');
require('can-list');
var define = {};
var inSetupSymbol = canSymbol.for('can.initializing');
var hasDefaultForSerialize = function (defaultDefinition) {
return typeof defaultDefinition === 'object' && 'serialize' in defaultDefinition;
};
var getDefaultForSerialize = function (defaultDefinition) {
var shouldSerialize = true;
if (hasDefaultForSerialize(defaultDefinition)) {
shouldSerialize = !!defaultDefinition.serialize;
}
return shouldSerialize;
};
var keysForDefinition = function (definitions) {
var keys = [];
var defaultDefinition = definitions && definitions['*'];
for (var prop in definitions) {
var definition = definitions[prop];
var shouldSerialize = getDefaultForSerialize(defaultDefinition);
if (typeof definition === 'object' && 'serialize' in definition) {
shouldSerialize = !!definition.serialize;
} else if (typeof definition === 'object' && !hasDefaultForSerialize(defaultDefinition)) {
shouldSerialize = !definition.get;
}
if (shouldSerialize) {
keys.push(prop);
}
}
return keys;
};
var getPropDefineBehavior = function (behavior, attr, define) {
var prop, defaultProp;
if (define) {
prop = define[attr];
defaultProp = define['*'];
if (prop && prop[behavior] !== undefined) {
return prop[behavior];
} else if (defaultProp && defaultProp[behavior] !== undefined) {
return defaultProp[behavior];
}
}
};
mapHelpers.define = function (Map, baseDefine) {
var definitions = Map.prototype.define;
if (baseDefine) {
var defines = {};
mapHelpers.twoLevelDeepExtend(defines, baseDefine);
mapHelpers.twoLevelDeepExtend(defines, definitions);
extend(definitions, defines);
}
Map.defaultGenerators = {};
for (var prop in definitions) {
var type = definitions[prop].type;
if (typeof type === 'string') {
if (typeof define.types[type] === 'object') {
delete definitions[prop].type;
extend(definitions[prop], define.types[type]);
}
}
if ('value' in definitions[prop]) {
if (typeof definitions[prop].value === 'function') {
Map.defaultGenerators[prop] = definitions[prop].value;
} else {
Map.defaults[prop] = definitions[prop].value;
}
}
if (typeof definitions[prop].Value === 'function') {
(function (Constructor) {
Map.defaultGenerators[prop] = function () {
return new Constructor();
};
}(definitions[prop].Value));
}
}
};
var oldSetupDefaults = CanMap.prototype._setupDefaults;
CanMap.prototype._setupDefaults = function (obj) {
var defaults = extend({}, oldSetupDefaults.call(this)), propsCommittedToAttr = {}, Map = this.constructor, originalGet = this._get;
this._get = function (originalProp) {
var prop = originalProp.indexOf('.') !== -1 ? originalProp.substr(0, originalProp.indexOf('.')) : originalProp;
if (prop in defaults && !(prop in propsCommittedToAttr)) {
this.attr(prop, defaults[prop]);
propsCommittedToAttr[prop] = true;
}
return originalGet.apply(this, arguments);
};
for (var prop in Map.defaultGenerators) {
if (!obj || !(prop in obj)) {
defaults[prop] = Map.defaultGenerators[prop].call(this);
}
}
delete this._get;
return defaults;
};
var proto = CanMap.prototype, oldSet = proto.__set;
proto.__set = function (prop, value, current, success, error) {
var self = this;
var errorCallback = function (errors) {
var stub = error && error.call(self, errors);
if (stub !== false) {
mapEventsMixin.dispatch.call(self, 'error', [
prop,
errors
], true);
}
return false;
}, setter = getPropDefineBehavior('set', prop, this.define), getter = getPropDefineBehavior('get', prop, this.define);
if (setter) {
queues.batch.start();
var setterCalled = false, setValue = setter.call(this, value, function (value) {
if (getter) {
self[prop](value);
} else {
oldSet.call(self, prop, value, current, success, errorCallback);
}
setterCalled = true;
}, errorCallback, getter ? this._computedAttrs[prop].compute.computeInstance.lastSetValue.get() : current);
if (getter) {
if (setValue !== undefined && !setterCalled && setter.length >= 1) {
this._computedAttrs[prop].compute(setValue);
}
queues.batch.stop();
return;
} else if (setValue === undefined && !setterCalled && setter.length > 1) {
queues.batch.stop();
return;
} else {
if (!setterCalled) {
oldSet.call(self, prop, setter.length === 0 && setValue === undefined ? value : setValue, current, success, errorCallback);
}
queues.batch.stop();
return this;
}
} else {
oldSet.call(self, prop, value, current, success, errorCallback);
}
return this;
};
define.types = {
'date': function (str) {
var type = typeof str;
if (type === 'string') {
str = Date.parse(str);
return isNaN(str) ? null : new Date(str);
} else if (type === 'number') {
return new Date(str);
} else {
return str;
}
},
'number': function (val) {
if (val == null) {
return val;
}
return +val;
},
'boolean': function (val) {
if (val == null) {
return val;
}
if (val === 'false' || val === '0' || !val) {
return false;
}
return true;
},
'htmlbool': function (val) {
return typeof val === 'string' || !!val;
},
'*': function (val) {
return val;
},
'string': function (val) {
if (val == null) {
return val;
}
return '' + val;
},
'compute': {
set: function (newValue, setVal, setErr, oldValue) {
if (newValue && newValue.isComputed) {
return newValue;
}
if (oldValue && oldValue.isComputed) {
oldValue(newValue);
return oldValue;
}
return newValue;
},
get: function (value) {
return value && value.isComputed ? value() : value;
}
}
};
var oldType = proto.__type;
proto.__type = function (value, prop) {
var type = getPropDefineBehavior('type', prop, this.define), Type = getPropDefineBehavior('Type', prop, this.define), newValue = value;
if (typeof type === 'string') {
type = define.types[type];
}
if (type || Type) {
if (type) {
newValue = type.call(this, newValue, prop);
}
if (Type && newValue != null && !(newValue instanceof Type)) {
newValue = new Type(newValue);
}
return newValue;
} else if (canReflect.isPlainObject(newValue) && newValue.define) {
newValue = CanMap.extend(newValue);
newValue = new newValue();
}
return oldType.call(this, newValue, prop);
};
var oldRemove = proto.__remove;
proto.__remove = function (prop, current) {
var remove = getPropDefineBehavior('remove', prop, this.define), res;
if (remove) {
queues.batch.start();
res = remove.call(this, current);
if (res === false) {
queues.batch.stop();
return;
} else {
res = oldRemove.call(this, prop, current);
queues.batch.stop();
return res;
}
}
return oldRemove.call(this, prop, current);
};
var oldSetupComputes = proto._setupComputedProperties;
proto._setupComputedProperties = function () {
oldSetupComputes.apply(this, arguments);
for (var attr in this.define) {
var def = this.define[attr], get = def.get;
if (get) {
mapHelpers.addComputedAttr(this, attr, compute.async(undefined, get, this));
}
if (def.resolver) {
mapHelpers.addComputedAttr(this, attr, new Resolver(def.resolver, this, def.value));
}
}
};
var oldSingleSerialize = proto.___serialize;
var serializeProp = function (map, attr, val) {
var serializer = attr === '*' ? false : getPropDefineBehavior('serialize', attr, map.define);
if (serializer === undefined) {
return oldSingleSerialize.call(map, attr, val);
} else if (serializer !== false) {
return typeof serializer === 'function' ? serializer.call(map, val, attr) : oldSingleSerialize.call(map, attr, val);
}
};
proto.___serialize = function (name, val) {
return serializeProp(this, name, val);
};
var oldSerialize = proto.serialize;
proto.serialize = function (property) {
var serialized = oldSerialize.apply(this, arguments);
if (property) {
return serialized;
}
var serializer, val;
for (var attr in this.define) {
if (!(attr in serialized)) {
serializer = this.define && (this.define[attr] && this.define[attr].serialize || this.define['*'] && this.define['*'].serialize);
if (serializer) {
val = serializeProp(this, attr, this.attr(attr));
if (val !== undefined) {
serialized[attr] = val;
}
}
}
}
return serialized;
};
canReflect.assignSymbols(proto, {
'can.hasKey': function (key) {
var defined = this.define && key in this.define;
var dataExists = this._data && key in this._data;
var propExists = key in this;
return defined || dataExists || propExists;
},
'can.getOwnEnumerableKeys': function () {
if (!this[inSetupSymbol]) {
ObservationRecorder.add(this, '__keys');
}
var definedKeys = keysForDefinition(this.define);
var dataKeys = Object.keys(this._data);
var shouldSerialize = getDefaultForSerialize(this.define && this.define['*']);
var enumerable = this.constructor.enumerable;
dataKeys = dataKeys.filter(function (key) {
return enumerable ? shouldSerialize && enumerable[key] !== false : shouldSerialize;
});
var i, newKey;
for (i = 0; i < dataKeys.length; i++) {
newKey = dataKeys[i];
if (definedKeys.indexOf(newKey) < 0 && (!this.define || !this.define[newKey])) {
definedKeys.push(dataKeys[i]);
}
}
return definedKeys;
}
});
module.exports = define;
});
Loading

0 comments on commit 4d04968

Please sign in to comment.