本文整理匯總了TypeScript中moment-timezone.utc函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript utc函數的具體用法?TypeScript utc怎麽用?TypeScript utc使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了utc函數的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: transform
transform(value: any, timezoneFrom?: string, timezoneTo?: string): string {
if (typeof value === 'string') {
value = parseInt(value, 10);
if (isNaN(value)) {
return '';
}
}
if (typeof value !== 'number' && !(value instanceof Date) && !moment.isMoment(value)) {
return '';
}
if (!timezoneFrom) {
return typeof value === 'number'
? this.hourToString(value)
: moment.utc(value).format('HH:mm');
} else {
timezoneTo = timezoneTo ? timezoneTo : moment.tz.guess();
return moment
.tz(
typeof value === 'number'
? this.hourToString(value)
: moment.utc(value).format('HH:mm'),
'HH:mm',
timezoneFrom
)
.tz(timezoneTo)
.format('HH:mm');
}
}
示例2: it
it('should format date/moment objects correctly with timezones', () => {
expect(pipe.transform(new Date('2014-06-01T16:16:00Z'), 'America/Toronto', 'America/Toronto')).toBe('16:16');
expect(pipe.transform(new Date('2014-06-01T07:00:00Z'), 'America/Toronto', 'Europe/Berlin')).toBe('13:00');
expect(pipe.transform(moment('2014-06-01T07:00:00Z'), 'America/Toronto', 'Europe/Berlin')).toBe('13:00');
expect(pipe.transform(moment.utc('2014-06-01T07:00:00Z'), 'America/Toronto', 'Europe/Berlin')).toBe('13:00');
expect(pipe.transform(moment('2014-06-01T18:30:00Z'), 'America/Toronto', 'Europe/Berlin')).toBe('00:30');
expect(pipe.transform(moment('2014-06-01T09:30:00Z'), 'America/Toronto', 'Europe/Berlin')).toBe('15:30');
});
示例3: RegExp
export const signupMember = (member: MemberInterface): Promise<any> =>
MemberModel.findOneAndUpdate(
{
firstname: { $in: new RegExp(`^${member.firstname}$`, 'i') },
familyname: { $in: new RegExp(`^${member.familyname}$`, 'i') },
emailaddress: { $in: new RegExp(`^${member.emailaddress}$`, 'i') },
postcode: { $in: new RegExp(`^${member.postcode}$`, 'i') },
dob: { $eq: moment.utc(member.dob) }
},
{
password: bcrypt.hashSync(member.password)
});
示例4: catch
export const formatDate = (date: string, options: FormatDateOptions = {}): string | null => {
let time;
try {
// Unknown error was causing this to crash in rare situations.
time = moment.utc(date).tz(options.timezone || 'GMT');
}
catch(e) {
// Better to return a blank date than an error or incorrect information.
reportException(e);
return null;
}
const formattedTime = shouldHumanize(time, options.humanizeCutoff)
? time.fromNow()
: time.format(options.format || ISO_FORMAT)
return formattedTime;
};
示例5: pathOr
export const formatDate = (
date: string,
options: FormatDateOptions = {}
): string => {
let time;
/** get the timezone from redux and use it as the moment timezone */
const reduxProfile = store.getState().__resources.profile;
const userTimezone = pathOr('GMT', ['data', 'timezone'], reduxProfile);
try {
// Unknown error was causing this to crash in rare situations.
time = moment.utc(date).tz(userTimezone);
} catch (e) {
// Better to return a blank date than an error or incorrect information.
reportException(e);
return 'Error getting datetime';
}
const formattedTime = shouldHumanize(time, options.humanizeCutoff)
? time.fromNow()
: time.format(options.format || ISO_FORMAT);
return formattedTime;
};
示例6: showTop
//.........這裏部分代碼省略.........
}
sorted = _.orderBy(users, 'value', 'desc');
break;
case TYPE.POINTS:
if (!global.systems.points.isEnabled()) {
return;
}
sorted = [];
for (const user of (await global.db.engine.find('users.points', { _sort: 'points', _sum: 'points', _total, _group: 'id' }))) {
sorted.push({ username: await global.users.getNameById(user._id), value: user.points });
}
message = global.translate('systems.top.points').replace(/\$amount/g, 10);
break;
case TYPE.MESSAGES:
sorted = [];
for (const user of (await global.db.engine.find('users.messages', { _sort: 'messages', _sum: 'messages', _total, _group: 'id' }))) {
sorted.push({ username: await global.users.getNameById(user._id), value: user.messages });
}
message = global.translate('systems.top.messages').replace(/\$amount/g, 10);
break;
case TYPE.FOLLOWAGE:
sorted = [];
for (const user of (await global.db.engine.find('users', { is: { follower: true }, _sort: '-time.follow', _total }))) {
sorted.push({ username: user.username, value: user.time.follow });
}
message = global.translate('systems.top.followage').replace(/\$amount/g, 10);
break;
case TYPE.SUBAGE:
sorted = [];
for (const user of (await global.db.engine.find('users', { is: { subscriber: true }, _sort: '-time.subscribed_at', _total }))) {
sorted.push({ username: user.username, value: user.time.subscribed_at });
}
message = global.translate('systems.top.subage').replace(/\$amount/g, 10);
break;
case TYPE.BITS:
sorted = [];
for (const user of (await global.db.engine.find('users.bits', { _sort: 'amount', _sum: 'amount', _total, _group: 'id' }))) {
sorted.push({ username: await global.users.getNameById(user._id), value: user.amount });
}
message = global.translate('systems.top.bits').replace(/\$amount/g, 10);
break;
case TYPE.GIFTS:
sorted = [];
for (const user of (await global.db.engine.find('users', { _sort: 'custom.subgiftCount', _total }))) {
sorted.push({ username: user.username, value: user.custom.subgiftCount });
}
message = global.translate('systems.top.gifts').replace(/\$amount/g, 10);
break;
}
if (sorted.length > 0) {
// remove ignored users
const ignored: string[] = [];
for (const user of sorted) {
if (isIgnored(user.username)) {
ignored.push(user.username);
}
}
_.remove(sorted, (o) => _.includes(ignored, o.username));
// remove broadcaster and bot accounts
_.remove(sorted, (o) => _.includes([getChannel(), global.oauth.settings.bot.username.toLowerCase()], o.username));
sorted = _.chunk(sorted, 10)[0];
for (const user of sorted) {
message += (i + 1) + '. ' + (global.tmi.settings.chat.showWithAt ? '@' : '') + (user.username || 'unknown') + ' - ';
switch (type) {
case TYPE.TIME:
message += (user.value / 1000 / 60 / 60).toFixed(1) + 'h';
break;
case TYPE.TIPS:
message += user.value.toFixed(2) + global.currency.symbol(global.currency.settings.currency.mainCurrency);
break;
case TYPE.POINTS:
message += user.value + ' ' + await global.systems.points.getPointsName(user.value);
break;
case TYPE.MESSAGES:
case TYPE.BITS:
case TYPE.GIFTS:
message += String(user.value);
break;
case TYPE.FOLLOWAGE:
case TYPE.SUBAGE:
message += `${moment.utc(user.value).format('L')} (${moment.utc(user.value).fromNow()})`;
break;
}
if (i + 1 < 10 && !_.isNil(sorted[i + 1])) {
message += ', ';
}
i++;
}
} else {
message += 'no data available';
}
if (__DEBUG__) {
global.log.debug(message);
}
sendMessage(message, opts.sender);
}