(function (global, factory) {
// 重写factory方法.让factory有独立的作用域
var _factory = factory; factory = function(arkWeb, wasmoon) { return function(options) { return _factory(arkWeb, wasmoon)(options); }};
typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory(require('@tencent/ark-web')) :
typeof define === 'function' && define.amd ? define(['@tencent/ark-web'], factory) :
(global.Ark = factory(global.WebArk));
})(this, (function (arkWeb) {
/**
* @fileoverview 前置脚本注入(polyfill)
* @author alawnxu
* @date 2022-07-30 22:20:00
* @version 1.0.0
* @description 这个是一个模块文件. 变量请采用: __VAR__ 方式命名
*
* 在Ark引擎中默认支持了 JSON.Stringify 和 JSON.Parse @see {@link /Users/alawnxu/workspace/qq/Ark/src/libs/net/httpwrapper.cpp}
* 其实同 Net.JSONToTable 和 Net.TableToJSON
*
* 在这里就通过注入的方式注册进去吧
*
* 涉及到这个Api的Ark. 游戏中心所有的Ark因为走了单独的构建,所以都会使用到这个Api
* @see {@link https://git.woa.com/sq-gamecenter-frontend-team/gc-ark-hub/tree/master/com_tencent_gamecenter_game_download}
* @see {@link https://git.woa.com/group-pro/bot-frontend/bot-ark/tree/master/com_tencent_bot_groupbot}
*/
(function() {
JSON.Stringify = JSON.Stringify || JSON.stringify;
JSON.Parse = JSON.Parse || JSON.parse;
})();
/**
* @fileoverview 前置脚本注入
* @author alawnxu
* @date 2022-04-09 23:26:29
* @version 1.0.0
* @description 这个是一个模块文件. 变量请采用: __VAR__ 方式命名
*/
/**
* 暴露出局部变量.方便后续的模块挂载
*/
let GlobalAppTemplates = {};
const ArkGlobalContext = {
/**
* @private
* @param {string} id 视图ID
* @param {string} template 视图模板
*/
_setViewTemplate(id, template) {
GlobalAppTemplates[id] = template;
},
/**
* 获取所有的模板
* @public
* @returns
*/
getViewTemplates() {
return GlobalAppTemplates;
},
/**
* 释放所有模板
* @date 2022-08-08 11:14:36
*/
clearTemplates() {
GlobalAppTemplates = {};
}
};
const ArkWindow = Object.create({});
const apis = ["console","global","detail_1","all","app","util","report","theme","notification","view_8C8E89B49BE609866298ADDFF2DBABA4","view_95A06A1683C80BECC99BE5CC7B6D706B","view_4473A8CC09D60E4199A9EF0437B14D50","view_472ADE9D43609B0F5AB20E86B765EEA3","view_A5D6E190E8364AB2AF4BF9F53A9BE1DC"];
apis.forEach(api => {
let val;
Object.defineProperty(ArkWindow, api, {
get() {
return val;
},
set(value) {
val = value;
}
});
});
/**
* @fileoverview 前置脚本注入(UI模块)
* @author alawnxu
* @date 2022-04-09 23:26:29
* @version 1.0.0
* @description 这个是一个模块文件. 变量请采用: __VAR__ 方式命名
*/
const UI = new Proxy(arkWeb.UI, {
get(target, propKey) {
const func = target[propKey];
if (typeof func === 'function') {
/**
* @description 这里之前传入global.app, 后面发现不太可行, 因为在Ark视图里面有注册了很多事件.这些事件的会直接调用里面声明的全局方法.这个时候就有可能不是在某一个对象上了.
* @update 2022年07月30日22:48:18
* @author alawnxu
*/
return function (...params) {
return target[propKey](...params, ArkWindow);
};
}
return target[propKey];
},
});
/**
* @fileoverview 前置脚本注入(Net模块)
* @author alawnxu
* @date 2022-04-09 23:26:29
* @version 1.0.0
* @description 这个是一个模块文件. 变量请采用: __VAR__ 方式命名
*/
const Net = new Proxy(arkWeb.Net, {
get(target, propKey) {
const func = target[propKey];
if (typeof func === 'function') {
/**
* @description 这里之前传入global.app, 后面发现不太可行, 因为在Ark视图里面有注册了很多事件.这些事件的会直接调用里面声明的全局方法.这个时候就有可能不是在某一个对象上了.
* @update 2022年07月30日22:48:18
* @author alawnxu
*/
return function (...params) {
return target[propKey](...params, ArkWindow);
};
}
return target[propKey];
},
});
ArkGlobalContext._setViewTemplate('detail_1', `
`);
ArkGlobalContext._setViewTemplate('all', `
`);
ArkGlobalContext._setViewTemplate('notification', `
`);
ArkGlobalContext._setViewTemplate('view_8C8E89B49BE609866298ADDFF2DBABA4', `
`);
ArkGlobalContext._setViewTemplate('view_95A06A1683C80BECC99BE5CC7B6D706B', `
`);
ArkGlobalContext._setViewTemplate('view_4473A8CC09D60E4199A9EF0437B14D50', `
`);
ArkGlobalContext._setViewTemplate('view_472ADE9D43609B0F5AB20E86B765EEA3', `
`);
ArkGlobalContext._setViewTemplate('view_A5D6E190E8364AB2AF4BF9F53A9BE1DC', `
`);
ArkWindow.console = {
MAX_LOG_DEPTH: 10,
_log: function(arg, depth) {
var res = [];
var type = typeof arg;
if (type == 'object') {
var keyLen = 0;
for (var key in arg) {
keyLen = keyLen + 1;
}
if (keyLen == 0) {
res.push(ArkWindow.console._toString(arg));
} else {
var tmp = [];
for (var i = 0; i < depth; ++i) {
tmp.push(' ');
}
tmp = tmp.join('');
var tmp1 = tmp + ' ';
res.push('{');
var i = 0;
for (var key in arg) {
res.push('\n' + tmp1 + key + ' : ');
if (depth >= ArkWindow.console.MAX_LOG_DEPTH) {
res.push(ArkWindow.console._toString(arg[key]));
} else {
res.push(ArkWindow.console._log(arg[key], depth + 1));
}
i = i + 1;
if (i < keyLen) {
res.push(',');
}
}
res.push('\n' + tmp + '}');
}
} else {
res.push(ArkWindow.console._toString(arg));
}
return res.join('');
},
_toString: function(arg) {
var type = Object.prototype.toString.call(arg);
if (type == '[object Null]') {
return 'Null';
} else if (type == '[object Undefined]') {
return 'Undefined';
} else if (type == '[object Number]' || type == '[object String]' || type == '[object Boolean]') {
return arg;
} else if (arg && arg.toString && typeof arg.toString == 'function') {
return arg.toString();
} else {
return 'Unknow Type';
}
},
log: function() {
var res = [];
for (var i = 0; i < arguments.length; ++i) {
res.push(ArkWindow.console._log(arguments[i], 0));
}
arkWeb.Console.Log('[log]:');
arkWeb.Console.Log(res.join('\n'));
},
warn: function() {
var res = [];
for (var i = 0; i < arguments.length; ++i) {
res.push(ArkWindow.console._log(arguments[i], 0));
}
arkWeb.Console.Log('[warn]:');
arkWeb.Console.Log(res.join('\n'));
},
error: function() {
var res = [];
for (var i = 0; i < arguments.length; ++i) {
res.push(ArkWindow.console._log(arguments[i], 0));
}
arkWeb.Console.Log('[error]:');
arkWeb.Console.Log(res.join('\n'));
}
};
var global$7 = ArkWindow;
ArkWindow.detail_1 = {
ViewModel: {
New: function(view) {
var model = Object.create(this);
model.Initialize(view);
return model;
},
Initialize: function(view) {
ArkWindow.console.log('detail_1 Initialize');
this.view = view;
//兜底数据
this.metaData = {
'title': 'QQ小程序',
'desc': '推荐你使用这个小程序',
'icon': 'image/icon.png',
'preview': 'image/preview.png',
'url': 'www.qq.com',
"appType": 0, // 0 小程序, 1 小游戏
"scene": 0,
"host": {
"uin": 0,
"nick": "昵称"
},
"shareTemplateId": "123",
"shareTemplateData": {
"txt1": "来自好友的邀请",
"txt2": "应邀前往"
}
};
this.appInfoWrapUIObj = view.GetUIObject("appInfoWrap");
this.originWrapUIObj = view.GetUIObject("originWrap");
this.titleForFooterUIObj = view.GetUIObject("titleForFooter");
this.footIconUIObj = view.GetUIObject("footIcon");
this.appLogoView = view.GetUIObject("appLogo");
this.appNameView = view.GetUIObject("appName");
this.appMsgTitleView = view.GetUIObject("appMsgTitle");
this.appMsgImageView = view.GetUIObject("appMsgImage");
this.appMsgContent = view.GetUIObject("appMsgContent");
this.appMsgAction = view.GetUIObject("appMsgAction");
this.splitLine_1 = view.GetUIObject("splitLine_1");
this.splitLine_2 = view.GetUIObject("splitLine_2");
var viewSize = this.view.GetSize();
this.OnResize(viewSize.width, viewSize.height);
// 绑定点击事件
var self = this;
this.appInfoWrapUIObj.AttachEvent("OnClick", function() {
self.OnClick();
});
this.originWrapUIObj.AttachEvent("OnClick", function() {
self.clickOriginWrapUI();
});
},
Deinitialize: function() {
ArkWindow.console.log('detail_1 Deinitialize');
},
OnResize: function(width, height) {
ArkWindow.console.log('detail_1 Deinitialize');
this.Update();
},
OnSetValue: function(sender, value) {
ArkWindow.console.log('OnSetValue', value);
var self = this;
this.metaData = value.detail_1 || this.metaData;
this.metaData.host.avatar = ArkWindow.util.getAvatar(this.metaData.host.uin, 100, 'qq');
this.Update();
// 曝光上报
var compassData = {
uin: self.metaData.host && this.metaData.host.uin || "",
appid: self.metaData.appid,
refer: self.metaData.scene,
actiontype: "ark",
sub_actiontype: "ark_share",
reserves_action: "expo",
reserves2: "com.tencent.miniapp_01",
reserves3: "detail_1",
reserves4: "",
reserves5: ArkWindow.util.getContainerInfo(self.view).group ? "group" : "c2c"
};
ArkWindow.report.compass(compassData, "dc04239");
},
OnClick: function(sender, x, y, button, keyState) {
var self = this;
ArkWindow.console.log('detail_1 OnClick');
//上报到ark表
ArkWindow.util.Report(this.view.GetRoot().GetID(), 3, "Button.OnClick");
var url = this.metaData["url"];
url = ArkWindow.util.fixurl(url);
url = ArkWindow.util.getMiniAppUrl(url, self.metaData["scene"], self.view);
ArkWindow.console.log("OpenUrl url:", url);
ArkWindow.console.log("befor OpenUrl");
arkWeb.QQ.OpenUrl(url, self.view.GetRoot());
ArkWindow.console.log("after OpenUrl");
// 点击上报
var containerInfo = ArkWindow.util.getContainerInfo(this.view);
var compassData = {
uin: self.metaData.host && this.metaData.host.uin || "",
appid: self.metaData.appid,
refer: self.metaData.scene,
actiontype: "ark",
sub_actiontype: "ark_share",
reserves_action: "click",
reserves2: "com.tencent.miniapp_01",
reserves3: "detail_1",
reserves4: "",
reserves5: ArkWindow.util.getChatTypeName(containerInfo.chatType),
app_type: this.metaData.appType || 0,
};
ArkWindow.report.compass(compassData, "dc04239");
},
clickOriginWrapUI: function() {
ArkWindow.console.log("clickOriginWrapUI");
ArkWindow.console.log(this.metaData.appType);
if (Number(this.metaData.appType) === 0 || !this.metaData.appType) {
this.OnClick();
return;
}
var url = "mqqapi://hippy/open?bundleName=miniGameCenter";
arkWeb.QQ.OpenUrl(url, this.view.GetRoot());
// 点击上报
var containerInfo = ArkWindow.util.getContainerInfo(this.view);
var compassData = {
uin: this.metaData.host && this.metaData.host.uin || "",
appid: this.metaData.appid,
refer: this.metaData.scene,
actiontype: "ark",
sub_actiontype: "ark_share",
reserves_action: "click_minigamestore",
reserves2: "com.tencent.miniapp_01",
reserves3: appView,
reserves5: ArkWindow.util.getChatTypeName(containerInfo.chatType),
touin: containerInfo.chatUIN,
app_type: this.metaData.appType || 0,
};
ArkWindow.report.compass(compassData, "dc04239");
},
/*resize和setvalue同意调用update,更新视图*/
Update: function() {
if (this.metaData.icon) {
ArkWindow.util.setImage(this.metaData.icon, this.appLogoView, function(err) {
if (err) {
ArkWindow.console.error('set Image error', err);
}
});
}
this.appNameView.SetValue(this.metaData.title);
this.appMsgTitleView.SetValue(this.metaData.desc);
if (this.metaData.host.avatar) {
ArkWindow.util.setImage(this.metaData.host.avatar, this.appMsgImageView, function(err) {
if (err) {
ArkWindow.console.error('set Image error', err);
}
});
}
this.appMsgContent.SetValue(this.metaData.shareTemplateData.txt1);
this.appMsgAction.SetValue(this.metaData.shareTemplateData.txt2);
this.titleForFooterUIObj.SetValue(ArkWindow.util.getFootTitleByAppType(this.metaData.appType));
this.footIconUIObj.SetValue(ArkWindow.util.getFootIconByAppType(this.metaData.appType));
if (global$7.Device && global$7.Device.GetPixelRatio) {
var radio = global$7.Device.GetPixelRatio();
ArkWindow.console.log('radio:', radio);
var height = (1 / radio).toFixed(4);
/*重构说,样式的height 是 1 / radio 取小数点4位*/
this.splitLine_1.SetStyle("position:absolute;left:0;top:0;right:0;height:" + height + ";");
this.splitLine_2.SetStyle("position:absolute;left:0;top:0;right:0;height:" + height + ";");
}
}
}
};
ArkWindow.global = global$7;
ArkWindow.all = {
ViewModel: {
New: function(view) {
var model = Object.create(this);
model.Initialize(view);
return model;
},
Initialize: function(view) {
this.view = view;
//兜底数据
this.metaData = {
'title': 'QQ小程序',
'summary': '推荐你使用这个小程序',
'preview': 'image/preview.png',
'jumpUrl': 'https://www.qq.com',
"buttonText": "开始游戏",
"buttonAction": "https://www.qq.com",
"appid": ""
};
this.titleUIObj = view.GetUIObject("appMsgTitle");
this.summaryUIObj = view.GetUIObject("appMsgText");
this.previewUIObj = view.GetUIObject("appMsgImage");
this.buttonUIObj = view.GetUIObject("appMsgAction");
var viewSize = this.view.GetSize();
this.OnResize(viewSize.width, viewSize.height);
this.Update();
},
Deinitialize: function() {},
OnResize: function(width, height) {
this.Update();
},
OnSetValue: function(sender, value) {
ArkWindow.console.log('OnSetValue', value);
if (value.all) {
this.metaData.title = value.all.title;
this.metaData.summary = value.all.summary;
this.metaData.preview = value.all.preview;
this.metaData.jumpUrl = value.all.jumpUrl;
this.metaData.appid = value.all.appid;
this.metaData.buttonText = value.all.buttons[0].name;
this.metaData.buttonAction = value.all.buttons[0].action;
}
this.Update();
this.report({
table: 'dc04239',
application: 'com.tencent.miniapp',
view: 'all',
type: 1,
action: 'expo'
});
},
OnClick: function(sender, x, y, button, keyState) {
var self = this;
var url = this.metaData.jumpUrl;
ArkWindow.console.log("OpenUrl url:", url);
this.report({
table: 'dc04239',
application: 'com.tencent.miniapp',
view: 'all',
type: 2,
action: 'click'
});
arkWeb.QQ.OpenUrl(url, self.view.GetRoot());
},
/*resize和setvalue同意调用update,更新视图*/
Update: function() {
if (this.metaData.preview) {
ArkWindow.util.setImage(this.metaData.preview, this.previewUIObj, function(err) {
if (err) {
ArkWindow.console.error('set Image error', err);
}
});
}
ArkWindow.console.log('update', this.metaData.buttonText);
this.buttonUIObj.SetValue(this.metaData.buttonText);
this.titleUIObj.SetValue(this.metaData.title);
this.summaryUIObj.SetValue(this.metaData.summary);
},
report: function(data) {
var http = Net.HttpRequest();
var version = '';
var os = arkWeb.System.GetOS();
var uin = '';
if (arkWeb.QQ && arkWeb.QQ.GetVersion) {
version = arkWeb.QQ.GetVersion();
}
if (arkWeb.QQ && arkWeb.QQ.GetUIN) {
uin = arkWeb.QQ.GetUIN();
}
var param = {
uin: uin,
appid: this.metaData.appid,
refer: 1014,
via: '1014_1',
actiontype: 'ark',
sub_actiontype: 'ark_message',
reserves_action: data.action,
reserves2: data.application,
reserves3: data.view,
reserves4: data.type,
device_platform: os,
qqversion: version,
t: new Date().getTime()
};
var url = 'https://h5.qzone.qq.com/report/compass/' + data.table + '?' + this.toUrlParams(param);
ArkWindow.console.log('report:', url);
http.Get(url);
},
toUrlParams: function(obj) {
var arr = [];
var k;
for (k in obj) {
if (obj.hasOwnProperty(k)) arr.push(encodeURIComponent(k) + '=' + encodeURIComponent(obj[k]));
}
return arr.join('&');
}
}
};
var global$6 = ArkWindow;
ArkWindow.app = {
viewModels: new Map(),
config: {},
GetModel: function(view) {
var viewRoot = view.GetRoot();
return ArkWindow.app.viewModels.get(viewRoot);
},
OnCreateView: function(view, template) {
ArkWindow.console.log('OnCreateView:', template);
if (global$6[template] && global$6[template].ViewModel && global$6[template].ViewModel.New) {
var viewRoot = view.GetRoot();
ArkWindow.app.viewModels.set(view, global$6[template].ViewModel.New(viewRoot));
} else {
ArkWindow.console.error('no model found for view: ' + template);
}
},
OnDestroyView: function(view, template) {
var model = ArkWindow.app.GetModel(view);
model.Deinitialize();
ArkWindow.app.viewModels.delete(view);
},
OnResize: function(sender, srcWidth, srcHeight, dstWidth, dstHeight) {
arkWeb.System.Tick();
var model = ArkWindow.app.GetModel(sender);
model && model.OnResize && model.OnResize(dstWidth, dstHeight);
},
OnSetValue: function(sender, value) {
var model = ArkWindow.app.GetModel(sender);
model && model.OnSetValue && model.OnSetValue(sender, value);
},
OnClick: function(sender, x, y, button, keyState) {
var model = ArkWindow.app.GetModel(sender);
model && model.OnClick && model.OnClick(sender, x, y, button, keyState);
},
OnStartup: function(config) {
ArkWindow.console.log('app OnStartup', config);
ArkWindow.app.config = config;
},
OnConfigChange: function(config) {
ArkWindow.console.log('app OnConfigChange', config);
ArkWindow.app.config = config;
ArkWindow.app.viewModels.forEach(function(a, view) {
var model = ArkWindow.app.GetModel(view);
model && model.OnConfigChange && model.OnConfigChange(ArkWindow.app.config);
});
}
};
var global$5 = ArkWindow;
(function(global) {
function createAssigner(keysFunc, defaults) {
return function(obj) {
var length = arguments.length;
if (defaults) obj = Object(obj);
if (length < 2 || obj == null) return obj;
for (var index = 1; index < length; index++) {
var source = arguments[index],
keys = keysFunc(source),
l = keys.length;
for (var i = 0; i < l; i++) {
var key = keys[i];
if (!defaults || obj[key] === void 0) obj[key] = source[key];
}
}
return obj;
};
}
function has(obj, path) {
return obj != null && Object.prototype.hasOwnProperty.call(obj, path);
}
function isObject(obj) {
var type = typeof obj;
return type === 'function' || type === 'object' && !!obj;
}
function allKeys(obj) {
if (!isObject(obj)) return [];
var keys = [];
for (var key in obj) keys.push(key);
return keys;
}
function keys(obj) {
if (!isObject(obj)) return [];
var keys = [];
for (var key in obj)
if (has(obj, key)) keys.push(key);
return keys;
}
var containerInfo;
global.util = {
fixurl: function(url, isHttps) {
if (url == "local" || !url) {
return url;
}
if (url.indexOf('miniapp://') == 0 || url.indexOf('res:') == 0 || ArkWindow.util.isLocalResUrl(url)) {
return url;
}
if (url.indexOf('m.q.qq.com') == 0) {
return "https://" + url;
}
if (url.indexOf('http:') == 0 || url.indexOf('https:') == 0) {
return url;
}
if (isHttps) {
return "https://" + url;
} else {
return "http://" + url;
}
},
isLocalResUrl: function(url) {
if (!url) {
return false;
}
url = url || "";
// res: url是上传/转存前预览的时候用的,是本地图片,直接设置到image元素即可
if (url.indexOf('image/') == 0 || url.indexOf('res:') == 0) {
return true;
} else {
return false;
}
},
createHttpRequest: function() {
if (Net && Net.HttpRequest) {
return Net.HttpRequest();
}
return Http.CreateHttpRequest();
},
httpDownload: function(url, callback) {
var httpGet = ArkWindow.util.createHttpRequest();
var httpStartTime = arkWeb.System.Tick();
arkWeb.Console.Log('start get resource ' + url + ' at ' + httpStartTime);
httpGet.SetTimeout(5000);
httpGet.AttachEvent("OnComplete", function(http) {
var httpEndTime = arkWeb.System.Tick();
arkWeb.Console.Log('end get resource ' + url + ' at ' + httpEndTime);
arkWeb.Console.Log('get resource ' + url + ' cost: ' + (httpEndTime - httpStartTime));
if (!http.IsSuccess()) {
callback({
code: http.GetStatusCode(),
msg: 'download url: ' + url + 'fail.'
});
return;
} else {
callback(null, http.GetCachePath());
}
});
httpGet.Get(url);
},
_setImage: function(url, viewObject, isHttps, retryTime, callback) {
var imageUrl = ArkWindow.util.fixurl(url, isHttps);
viewObject.AttachEvent('OnLoad', function() {
viewObject.DetachEvent("OnError");
viewObject.DetachEvent("OnLoad");
callback();
});
var path = arkWeb.Storage.Load(imageUrl);
if (path) {
viewObject.AttachEvent("OnError", function(sender) {
viewObject.DetachEvent("OnError");
viewObject.DetachEvent("OnLoad");
arkWeb.Storage.Save(imageUrl, "");
retryTime -= 1;
if (retryTime > 0) {
ArkWindow.util._setImage(url, viewObject, isHttps, retryTime, callback);
} else {
callback({
code: -1,
msg: 'load netwrok image error'
});
}
});
viewObject.SetValue(path);
return;
} else {
ArkWindow.util.httpDownload(imageUrl, function(err, path) {
if (err) {
retryTime -= 1;
if (retryTime > 0) {
ArkWindow.util._setImage(url, viewObject, isHttps, retryTime, callback);
} else {
callback(err);
}
} else {
arkWeb.Storage.Save(imageUrl, path);
viewObject.AttachEvent("OnError", function(sender) {
viewObject.DetachEvent("OnError");
viewObject.DetachEvent("OnLoad");
arkWeb.Storage.Save(imageUrl, "");
retryTime -= 1;
if (retryTime > 0) {
ArkWindow.util._setImage(url, viewObject, isHttps, retryTime, callback);
} else {
callback({
code: -1,
msg: 'load image error'
});
}
});
viewObject.SetValue(path);
return;
}
});
}
},
/*
设置图片元素的图片链接
*/
setImage: function(url, viewObject, callback) {
if (ArkWindow.util.isLocalResUrl(url)) {
arkWeb.Console.Log('set local image: ' + url);
viewObject.AttachEvent('OnLoad', function() {
viewObject.DetachEvent("OnError");
viewObject.DetachEvent("OnLoad");
callback();
});
viewObject.AttachEvent("OnError", function(sender) {
viewObject.DetachEvent("OnError");
viewObject.DetachEvent("OnLoad");
callback({
code: -1,
msg: 'load local image error'
});
});
viewObject.SetValue(url);
} else {
arkWeb.Console.Log('set netwrok image: ' + url);
//先用2次http,如果失败再用2次https
ArkWindow.util._setImage(url, viewObject, false, 2, function(err) {
// if (err) {
// util._setImage(url, viewObject, true, 2, function (err) {
// callback(err);
// })
// } else {
callback();
// }
});
}
},
isiOS: function() {
return arkWeb.System.GetOS() == "iOS";
},
isAndroid: function() {
return arkWeb.System.GetOS() == "Android";
},
isWindows: function() {
return arkWeb.System.GetOS() == "Windows";
},
isMac: function() {
return arkWeb.System.GetOS() == "Mac";
},
compareVersion: function(target, cmd) {
var _compare = function(tokens1, tokens2, p) {
if (!tokens1[p] && !tokens2[p]) {
return 0;
}
return ((tokens1[p] || 0) - (tokens2[p] || 0)) || _compare(tokens1, tokens2, p + 1);
};
if (arkWeb.QQ && arkWeb.QQ.GetVersion) {
var r = _compare(arkWeb.QQ.GetVersion().split('.'), (target + '').split('.'), 0);
r = r < 0 ? -1 : r > 0 ? 1 : 0;
switch (cmd) {
case 'eq':
return r === 0;
case 'neq':
return r !== 0;
case 'lt':
return r < 0;
case 'nlt':
return r >= 0;
case 'gt':
return r > 0;
case 'ngt':
return r <= 0;
default:
return r;
}
} else {
return false;
}
},
/*
检测当前QQ版本号是否低于指定版本号,现在支持iOS平台和Android平台
iOSTargetVersionStr iOS需要判断的版本号,字符串,三位,传入格式如"8.0.0“
androidTargetVersionStr android需要判断的版本号,字符串,三位,传入格式如”8.0.0“
*/
isCurrentQQVersionBelowTargetVersion: function(iOSTargetVersionStr, androidTargetVersionStr) {
if (ArkWindow.util.isiOS()) {
return ArkWindow.util.compareVersion(iOSTargetVersionStr, 'lt');
} else if (ArkWindow.util.isAndroid()) {
return ArkWindow.util.compareVersion(androidTargetVersionStr, 'lt');
} else {
return false;
}
},
getAvatar: function(uin, size, platform) {
if (!uin) {
return '';
}
size = size || 100;
platform = platform || 'qq';
if (platform != 'qq' || platform != 'qzone') {
platform = 'qq';
}
if (platform == 'qq') {
if (size != 40 || size != 100 || size != 140) {
size = 100;
}
return 'q.qlogo.cn/openurl/' + uin + '/' + uin + '/' + size + '?rf=qz_hybrid&c=' + ArkWindow.util.base62().encode('qz_hybrid@' + uin);
} else if (platform == 'qzone') {
if (size != 30 || size != 50 || size != 100) {
size = 100;
}
return 'qlogo' + (uin % 4 + 1) + '.store.qq.com/qzone/' + uin + '/' + uin + '/' + size;
}
},
base62: function() {
return {
decode: function(a) {
return ArkWindow.util.base64().decode(a.replace(/ic/g, '/').replace(/ib/g, '+').replace(/ia/g, 'i'));
},
encode: function(a) {
return ArkWindow.util.base64().encode(a).replace(/[=i\+\/]/g, function(m) {
switch (m) {
case '=':
return '';
case 'i':
return 'ia';
case '+':
return 'ib';
case '/':
return 'ic';
default:
return '';
}
});
}
};
},
base64: function() {
// constants
var b64chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';
var b64tab = function(bin) {
var t = {};
for (var i = 0, l = bin.length; i < l; i++) t[bin.charAt(i)] = i;
return t;
}(b64chars);
var fromCharCode = String.fromCharCode;
// encoder stuff
var cb_utob = function(c) {
if (c.length < 2) {
var cc = c.charCodeAt(0);
return cc < 0x80 ? c :
cc < 0x800 ? (fromCharCode(0xc0 | (cc >>> 6)) +
fromCharCode(0x80 | (cc & 0x3f))) :
(fromCharCode(0xe0 | ((cc >>> 12) & 0x0f)) +
fromCharCode(0x80 | ((cc >>> 6) & 0x3f)) +
fromCharCode(0x80 | (cc & 0x3f)));
} else {
var cc = 0x10000 +
(c.charCodeAt(0) - 0xD800) * 0x400 +
(c.charCodeAt(1) - 0xDC00);
return (fromCharCode(0xf0 | ((cc >>> 18) & 0x07)) +
fromCharCode(0x80 | ((cc >>> 12) & 0x3f)) +
fromCharCode(0x80 | ((cc >>> 6) & 0x3f)) +
fromCharCode(0x80 | (cc & 0x3f)));
}
};
var re_utob = /[\uD800-\uDBFF][\uDC00-\uDFFFF]|[^\x00-\x7F]/g;
var utob = function(u) {
return u.replace(re_utob, cb_utob);
};
var cb_encode = function(ccc) {
var padlen = [0, 2, 1][ccc.length % 3],
ord = ccc.charCodeAt(0) << 16 |
((ccc.length > 1 ? ccc.charCodeAt(1) : 0) << 8) |
((ccc.length > 2 ? ccc.charCodeAt(2) : 0)),
chars = [
b64chars.charAt(ord >>> 18),
b64chars.charAt((ord >>> 12) & 63),
padlen >= 2 ? '=' : b64chars.charAt((ord >>> 6) & 63),
padlen >= 1 ? '=' : b64chars.charAt(ord & 63)
];
return chars.join('');
};
var btoa = function(b) {
return b.replace(/[\s\S]{1,3}/g, cb_encode);
};
var _encode = function(u) {
return btoa(utob(u))
};
var encode = function(u, urisafe) {
return !urisafe ?
_encode(u) :
_encode(u).replace(/[+\/]/g, function(m0) {
return m0 == '+' ? '.' : '*';
}).replace(/=/g, '');
};
var encodeURI = function(u) {
return encode(u, true)
};
// decoder stuff
var re_btou = new RegExp([
'[\xC0-\xDF][\x80-\xBF]',
'[\xE0-\xEF][\x80-\xBF]{2}',
'[\xF0-\xF7][\x80-\xBF]{3}'
].join('|'), 'g');
var cb_btou = function(cccc) {
switch (cccc.length) {
case 4:
var cp = ((0x07 & cccc.charCodeAt(0)) << 18) |
((0x3f & cccc.charCodeAt(1)) << 12) |
((0x3f & cccc.charCodeAt(2)) << 6) |
(0x3f & cccc.charCodeAt(3)),
offset = cp - 0x10000;
return (fromCharCode((offset >>> 10) + 0xD800) +
fromCharCode((offset & 0x3FF) + 0xDC00));
case 3:
return fromCharCode(
((0x0f & cccc.charCodeAt(0)) << 12) |
((0x3f & cccc.charCodeAt(1)) << 6) |
(0x3f & cccc.charCodeAt(2))
);
default:
return fromCharCode(
((0x1f & cccc.charCodeAt(0)) << 6) |
(0x3f & cccc.charCodeAt(1))
);
}
};
var btou = function(b) {
return b.replace(re_btou, cb_btou);
};
var cb_decode = function(cccc) {
var len = cccc.length,
padlen = len % 4,
n = (len > 0 ? b64tab[cccc.charAt(0)] << 18 : 0) |
(len > 1 ? b64tab[cccc.charAt(1)] << 12 : 0) |
(len > 2 ? b64tab[cccc.charAt(2)] << 6 : 0) |
(len > 3 ? b64tab[cccc.charAt(3)] : 0),
chars = [
fromCharCode(n >>> 16),
fromCharCode((n >>> 8) & 0xff),
fromCharCode(n & 0xff)
];
chars.length -= [0, 0, 2, 1][padlen];
return chars.join('');
};
var atob = function(a) {
return a.replace(/[\s\S]{1,4}/g, cb_decode);
};
var _decode = function(a) {
return btou(atob(a))
};
var decode = function(a) {
return _decode(
a.replace(/[\.\*]/g, function(m0) {
return m0 == '.' ? '+' : '/'
})
.replace(/[^A-Za-z0-9\+\/]/g, '')
);
};
var Base64 = {
atob: atob,
btoa: btoa,
fromBase64: decode,
toBase64: encode,
utob: utob,
encode: encode, //这个方法是正宗的base64算法
encodeURI: encodeURI, //这个是根据我们后台变种的base64算法
btou: btou,
decode: decode
};
return Base64;
},
Report: function(id, index, action) {
if (arkWeb.QQ && arkWeb.QQ.Report) {
arkWeb.QQ.Report(id, index, action);
} else {
arkWeb.Console.Log('QQ does not have Report method');
}
},
ReportEx: function(type, data) {
if (arkWeb.QQ && arkWeb.QQ.ReportEx) {
arkWeb.QQ.ReportEx(type, data);
} else {
arkWeb.Console.Log('QQ does not have ReportEx method');
}
},
/*获取小程序url,因为url涉及版本兼容问题,所以收归到一个统一的方法*/
getMiniAppUrl: function(url, scene, view) {
// 获取scene值,如果传进来了scene,优先用传进来的,如果没传,判断AIO类型,单聊用1007,群聊用1008
// url 参数。在群组需要拼接群id _gid,在群组和讨论组需要拼接 _sessionid _sessiontype
url = url || "";
ArkWindow.console.log("url:", url);
var containerInfo = {
ChatType: "-1"
};
if (arkWeb.QQ.GetContainerInfo) {
containerInfo = arkWeb.QQ.GetContainerInfo(view.GetRoot());
}
var sceneValue = 1007;
var typeStr = containerInfo.ChatType;
var type = parseInt(typeStr, 10);
if (scene) {
// 后台有可能下发了 scene=0,为0的也不能取!
sceneValue = scene;
} else if (type != -1) {
if (type <= 2) {
sceneValue = 1007;
} else if (type > 2) {
sceneValue = 1008;
}
}
var surfix = [];
if (type != -1) {
if (type <= 2) {
surfix.push("scene=1007");
} else if (type > 2) {
surfix.push("scene=1008");
}
if (type == 3) {
surfix.push("&_gid=" + containerInfo.ChatUIN);
}
if (type == 3 || type == 4) {
surfix.push("&_sessionid=" + containerInfo.ChatUIN);
surfix.push("&_sessiontype=" + containerInfo.ChatType);
}
}
if (surfix.length) {
if (url.indexOf("?") != -1) {
url = url + "&" + surfix.join("&");
} else {
url = url + "?" + surfix.join("&");
}
}
ArkWindow.console.log("url:", url);
// 8.1.0以上版本正式QQ 都用这个schema打开,这个schema仅在ark场景适用
var jmpUrl = "miniapp://open/" + sceneValue + "?url=" + Net.UrlEncode(url);
// 安卓800 ios803以下不支持小程序,打开兜底页
if (ArkWindow.util.isCurrentQQVersionBelowTargetVersion("8.0.3", "8.0.0")) {
arkWeb.Console.Log('may be regular QQ but version not support miniapp');
jmpUrl = "https://m.q.qq.com/update";
}
// QQ8.1.0版本开始改用schema打开,8.1.0版本以前用http url打开
if (ArkWindow.util.isCurrentQQVersionBelowTargetVersion("8.1.0", "8.1.0")) {
arkWeb.Console.Log("may be regular QQ but version lower then 810, use http url");
jmpUrl = url;
}
// QQ极速版版本号从4.0.0开始,由于ark没有方法判断是否极速版,所以暂时把5.0.0以下的当作极速版
if (ArkWindow.util.isCurrentQQVersionBelowTargetVersion("5.0.0", "5.0.0")) {
arkWeb.Console.Log("may be quick QQ, can open miniapp");
jmpUrl = url;
}
// 不是小程序的地址的话,也不拼前缀了,直接打开
if (url.startsWith("https://m.q.qq.com/a/") || url.startsWith("http://m.q.qq.com/a/") || url.startsWith("mqqapi://microapp/open") || url.startsWith("mqqapi://miniapp/open") || url.startsWith("mqqapi://miniapp/adopen")) {
arkWeb.Console.Log("is miniapp url");
} else {
arkWeb.Console.Log("not miniapp url");
jmpUrl = url;
}
arkWeb.Console.Log("opening miniapp, url: " + jmpUrl);
return jmpUrl;
},
isExistBoldTitle: function(key, array) {
var titleLen = 0;
for (var i = 0, len = array.length; i < len; i++) {
if (array[i].title === key) {
titleLen++;
}
}
return titleLen;
},
toUrlParams: function(obj) {
var arr = [];
var k;
for (k in obj) {
if (obj.hasOwnProperty(k))
arr.push(encodeURIComponent(k) + "=" + encodeURIComponent(obj[k]));
}
return arr.join("&");
},
extend: createAssigner(allKeys),
extendOwn: createAssigner(keys),
getContainerInfo: function(view) {
if (containerInfo) {
return containerInfo;
}
if (arkWeb.QQ.GetContainerInfo) {
containerInfo = arkWeb.QQ.GetContainerInfo(view.GetRoot());
var chatType = parseInt(containerInfo.ChatType || "", 10) || 0;
var chatUIN = parseInt(containerInfo.ChatUIN || "", 10) || 0;
var group;
if (chatType == 3 || chatType == 4) {
group = true;
} else {
group = false;
}
containerInfo = {
chatType: chatType,
chatUIN: chatUIN,
group: group
};
} else {
containerInfo = {};
}
return containerInfo;
},
getChatTypeName(chatType) {
var chatTypeMap = [{
name: 'group',
chatTypes: [3, 4]
},
{
name: 'c2c',
chatTypes: [1, 2, 5, 6, -1]
},
{
name: 'channel',
chatTypes: [7]
}
];
var chatTypeItem = chatTypeMap.find(item => item.chatType === chatType);
return chatTypeItem && chatTypeItem.name || 'c2c';
},
getFootTitleByAppType: function(appType) {
ArkWindow.console.log("getFootTitleByAppType:", appType);
return ['QQ小程序', '进入小游戏中心 >'][Number(appType)];
},
getFootIconByAppType: function(appType) {
ArkWindow.console.log("getFootIconByAppType:", appType);
return ['image/icon-miniprogram@2x.png', 'image/icon-minigame@2x.png'][Number(appType)];
}
};
})(global$5);
ArkWindow.report = {
// 上报罗盘
compass: function(data, table) {
data = data || {};
if (!table) {
return;
}
var http = Net.HttpRequest();
var version = "";
var os = arkWeb.System.GetOS();
var uin = "";
if (typeof arkWeb.QQ != "undefined" && arkWeb.QQ.GetVersion) {
version = arkWeb.QQ.GetVersion();
}
if (typeof arkWeb.QQ != "undefined" && arkWeb.QQ.GetUIN) {
uin = arkWeb.QQ.GetUIN();
}
var touin = data.uin || "";
delete data.uin;
var param = ArkWindow.util.extendOwn({
uin: uin,
touin: touin,
appid: "",
refer: "",
actiontype: "",
sub_actiontype: "",
reserves_action: "",
reserves2: "",
reserves3: "",
reserves4: "",
device_platform: os,
qqversion: version,
timestamp: Date.now()
}, data);
ArkWindow.console.log("reportn compass param:", param);
var url = "https://h5.qzone.qq.com/report/compass/" + table + "?" + ArkWindow.util.toUrlParams(param);
ArkWindow.console.log("reportn compass url:", url);
http.Get(url);
}
};
ArkWindow.theme = {
// 手Q主题ID
ThemeID: {
ConciseWhite: "2971", // 主题ID:2971——简洁模式白色
ConciseGray: "2921", // 主题ID:2921——简洁模式灰色
ConciseBlack: "2920", // 主题ID: 2920——简洁模式黑色
DefaultDefault: "2100", // 主题ID: 2100——默认模式默认颜色
AndroidDefaultBlack: "1103", // 主题ID: 1103——默认模式黑色
iOSDefaultBlack: "1102", // 主题ID: 1103——默认模式黑色
ConciseGreen: "3063", // 主题ID:3063——简洁模式-绿色
ConciseYellow: "3064", // 主题ID:3064——简洁模式-黄色
ConcisePurple: "3065", // 主题ID:3065——简洁模式-紫色
ConcisePink: "3066", // 主题ID:3066——简洁模式-粉色
ConciseRed: "3067", // 主题ID:3067——简洁模式-红色
TIMDefault: "1015712", // TIM 默认主题
},
// 当前是否是频道AIO
isCurrentInGuildAIO: function(view) {
// 测试频道代码
// return true
var containerInfo = arkWeb.QQ.GetContainerInfo(view.GetRoot());
if (!containerInfo) {
ArkWindow.console.log('get container info return null');
return false;
}
ArkWindow.console.log('current chat type is:', containerInfo.ChatType);
// 手Q定义的频道类型
var AIO_TYPE_GUILD = "7";
return AIO_TYPE_GUILD == containerInfo.ChatType;
},
// 当前是否是夜间模式
isDarkMode: function() {
if (ArkWindow.app.config && ArkWindow.app.config.theme) {
var themeId = ArkWindow.app.config.theme.themeId;
return themeId == this.ThemeID.ConciseBlack ||
themeId == this.ThemeID.AndroidDefaultBlack ||
themeId == this.ThemeID.iOSDefaultBlack
}
return false;
},
// 当前是否是简洁模式
isConciseMode: function() {
if (ArkWindow.app.config && ArkWindow.app.config.theme) {
return ArkWindow.app.config.theme.mode == "concise";
}
return false;
}
};
ArkWindow.notification = {
ViewModel: {
New: function(view) {
var model = Object.create(this);
model.Initialize(view);
return model;
},
Initialize: function(view) {
ArkWindow.console.log('notification Initialize');
this.view = view;
//兜底数据
this.metaData = {
"appInfo": {
"appid": 0,
"appType": 4,
"appName": "",
"iconUrl": ""
},
"title": "订单取消通知",
"emphasis_keyword": "加粗字段标题",
"data": [{
"title": "加粗字段标题",
"value": "加粗字段内容"
},
{
"title": "字段标题",
"value": "字段内容"
},
{
"title": "字段标题",
"value": "字段内容"
}
],
"button": [{
"name": "进入小程序查看详情",
"action": ""
},
{
"name": "拒绝通知",
"action": ""
}
]
};
this.appEventView = view.GetUIObject("appEvent");
this.appLogoView = view.GetUIObject("appLogo");
this.appNameView = view.GetUIObject("appName");
this.appMsgContent = view.GetUIObject('appMsgContent');
this.appMsgTypeView = view.GetUIObject("appMsgType");
this.appMsgDetailView = view.GetUIObject("appMsgDetail");
this.appMsgTxtView = view.GetUIObject("appMsgTxt");
this.notificationView = this.view.GetRoot();
var self = this;
view.GetUIObject("appMsgContentWrap").AttachEvent("OnClick", function() {
// 整个内容区域
ArkWindow.console.log('notification appMsgContentWrap OnClick');
//上报到ark表
ArkWindow.util.Report(self.view.GetRoot().GetID(), 3, "Button.OnClick");
var url = self.metaData["button"][0]["action"];
url = ArkWindow.util.fixurl(url);
self.jumpToUrl(url);
self.reportClick();
});
view.GetUIObject("appMsgAction1").AttachEvent("OnClick", function() {
// 查看详情
ArkWindow.console.log('notification appMsgAction1 OnClick');
//上报到ark表
ArkWindow.util.Report(self.view.GetRoot().GetID(), 3, "Button.OnClick");
var url = self.metaData["button"][0]["action"];
url = ArkWindow.util.fixurl(url);
self.jumpToUrl(url);
self.reportClick();
});
var viewSize = this.view.GetSize();
this.OnResize(viewSize.width, viewSize.height);
this.changeBg(ArkWindow.app.config);
},
Deinitialize: function() {
ArkWindow.console.log('notification Deinitialize');
},
OnResize: function(width, height) {
// console.log('notification OnResize');
// this.Update();
},
OnSetValue: function(sender, value) {
ArkWindow.console.log('OnSetValue', value);
var self = this;
this.metaData = value.notification || this.metaData;
this.height = this.metaData.data.length * 6 + 40;
var len = ArkWindow.util.isExistBoldTitle(this.metaData.emphasis_keyword, this.metaData.data);
if (len !== 0) {
// 加上加粗和减少原来本在小标题的高度
this.height = (this.height - 6 * len) + 15;
}
// 如果没有配置拒收通知的action就不要显示拒收通知了
if ((!self.metaData["button"][1]) || (!self.metaData["button"][1]["action"])) {
this.view.GetUIObject("appMsgAction2").SetStyle("display:none;");
} else if (self.metaData["button"][1]["action"]) {
this.view.GetUIObject("appMsgAction2").AttachEvent("OnClick", function() {
// 拒收通知
ArkWindow.console.log('notification appMsgAction2 OnClick');
//上报到ark表
ArkWindow.util.Report(self.view.GetRoot().GetID(), 3, "Button.OnClick");
var url = self.metaData["button"][1]["action"];
arkWeb.QQ.OpenUrl(url, self.view.GetRoot());
self.reportClick();
});
}
// this.notificationView.SetStyle(`display:flex;flexDirection:column;width:90vw;height:${this.height}vw;`)
this.Update();
// 曝光上报
var compassData = {
uin: self.metaData.host && self.metaData.host.uin || "",
appid: self.metaData.appInfo && self.metaData.appInfo.appid || 0,
refer: self.metaData.scene || 0,
actiontype: "ark",
sub_actiontype: "ark_message",
reserves_action: "expo",
reserves2: "com.tencent.miniapp_01",
reserves3: "notification",
reserves4: "",
};
ArkWindow.report.compass(compassData, "dc04239");
},
OnConfigChange: function(config) {
ArkWindow.console.log('notification OnConfigChange', config);
this.changeBg(config);
},
changeBg(config) {
var themeObj = {
ConciseWhite: 2971, //--主题ID:2971——简洁模式白色
ConciseGray: 2921, //--主题ID:2921——简洁模式灰色
ConciseBlack: 2920 //--主题ID: 2920——简洁模式黑色
};
if (config && config.theme) {
var texture = this.view.GetTexture('bgColor');
var theme = config.theme;
if (texture) {
var themeId = theme.themeId + "";
theme.mode;
if (themeId == themeObj.ConciseWhite) {
ArkWindow.console.log('setBackground ConciseWhite');
texture.SetValue(0xFFF5F6FA);
} else if (themeId == themeObj.ConciseGray) {
ArkWindow.console.log('setBackground ConciseGray');
texture.SetValue(0xFFFFFFFF);
} else if (themeId == themeObj.ConciseBlack) {
ArkWindow.console.log('setBackground ConciseBlack');
texture.SetValue(0xFFFFFFFF);
} else {
ArkWindow.console.log('setBackground nothing');
}
}
}
},
jumpToUrl: function(url) {
var jumpUrl;
var scene = '1014'; // 1014 模版消息 2085订阅消息
// 模版消息&订阅消息不用util.getMiniAppUrl的原因:要上报一个特殊scene值,而安卓和iOS的要上报这个值的url还不同,不能用util.getMiniAppUrl里面的统一scheme
if (ArkWindow.util.isCurrentQQVersionBelowTargetVersion("8.2.6", "8.2.6")) {
if (ArkWindow.util.isiOS()) {
ArkWindow.console.log('ios');
jumpUrl = 'mqqapi://microapp/open?url=' + encodeURIComponent(url);
} else {
jumpUrl = url;
}
ArkWindow.console.log('jumpUrl:' + jumpUrl);
arkWeb.QQ.OpenUrl(jumpUrl, this.view.GetRoot());
} else {
// 以上是 820版本及820以前的情况
// 826开始,安卓和iOS又统一成一样了。hehe~
var temp = url.match(/scene=(\d+)/);
if (temp && temp[1]) {
scene = temp[1];
}
jumpUrl = ArkWindow.util.getMiniAppUrl(url, scene, this.view);
ArkWindow.console.log('jumpUrl:' + jumpUrl);
arkWeb.QQ.OpenUrl(jumpUrl, this.view.GetRoot());
}
},
reportClick: function() {
var self = this;
// 曝光上报
var compassData = {
uin: self.metaData.host && self.metaData.host.uin || "",
appid: self.metaData.appInfo && self.metaData.appInfo.appid || 0,
refer: self.metaData.scene || 0,
actiontype: "ark",
sub_actiontype: "ark_message",
reserves_action: "click",
reserves2: "com.tencent.miniapp_01",
reserves3: "notification",
reserves4: "",
};
ArkWindow.report.compass(compassData, "dc04239");
},
/*resize和setvalue同意调用update,更新视图*/
Update: function() {
ArkWindow.console.log('Update');
if (!this.metaData || !this.metaData.appInfo) {
return;
}
if (this.metaData.appInfo.iconUrl) {
ArkWindow.util.setImage(this.metaData.appInfo.iconUrl, this.appLogoView, function(err) {
if (err) {
ArkWindow.console.error('set Image error', err);
}
});
}
this.appEventView.SetValue(this.metaData.title);
this.appNameView.SetValue(this.metaData.appInfo.appName);
this.appMsgDetailView.ClearChildren();
if (ArkWindow.util.isExistBoldTitle(this.metaData.emphasis_keyword, this.metaData.data) === 0) {
this.appMsgContent.SetStyle('display:none');
}
// 缓存 titleTempText 相关信息
var titleUIObj = [];
var titleObj = [];
for (var i = 0, len = this.metaData.data.length; i < len; i++) {
/*
动态插入元素,可能会导致SetMultiline失效,
需要把
titleTempText.SetValue(this.metaData.data[i].title);
contentTempText.SetValue(this.metaData.data[i].value);
放到最下面。
TODO 具体原因需要找ruifanyuan确认清楚
*/
if (this.metaData.data[i].title === this.metaData.emphasis_keyword) {
this.appMsgTypeView.SetValue(this.metaData.data[i].title);
this.appMsgTxtView.SetValue(this.metaData.data[i].value);
if (this.metaData.data[i].value.length > 24) {
this.appMsgTxtView.SetValue(this.metaData.data[i].value.slice(0, 24));
}
continue;
}
var tempView = UI.View();
tempView.SetStyle("display:flex;flexDirection:row;alignItems:flex-start;marginTop:4;");
var titleTempText = UI.Text();
titleTempText.SetStyle("display:block;width:auto;");
titleTempText.SetTextColor(0xFF878B99);
titleTempText.SetFont("size.14");
titleTempText.SetAutoSize(true);
// titleTempText.SetMultiline(true);
var contentTempText = UI.Text();
contentTempText.SetStyle("display:block;flex:1;marginLeft:12;");
contentTempText.SetTextColor(0xFF03081A);
contentTempText.SetFont("size.14");
contentTempText.SetAutoSize(true);
contentTempText.SetMultiline(true);
tempView.AddChild(titleTempText);
tempView.AddChild(contentTempText);
this.appMsgDetailView.InsertChild(i, tempView);
// 这两个元素设置value需要放到最下面这里来
titleTempText.SetValue(this.metaData.data[i].title);
contentTempText.SetValue(this.metaData.data[i].value);
// 存入每个 titleTempText 的宽度和高度
titleUIObj.push(titleTempText.GetSize());
titleObj.push(titleTempText);
}
// 找出最长的 titleTempText 宽度
var titleMaxWidth = 0;
for (var j = 0, len = titleUIObj.length; j < len; j++) {
if (titleUIObj[j].width > titleMaxWidth) {
titleMaxWidth = titleUIObj[j].width;
}
}
// 重设 titleTempText 的 setStyle
for (var k = 0, len = titleObj.length; k < len; k++) {
titleObj[k].SetStyle("display:block;width:" + titleMaxWidth);
}
}
}
};
var global$4 = ArkWindow;
(function() {
// 搞成闭包,避免污染全局变量
var appView = "view_8C8E89B49BE609866298ADDFF2DBABA4";
global$4[appView] = {
appView: appView,
ViewModel: {
New: function(view) {
var model = Object.create(this);
model.Initialize(view);
return model;
},
Initialize: function(view) {
this.view = view;
// 兜底数据
this.metaData = {
"appid": "",
"icon": "image/icon.png",
"title": "QQ小程序",
"desc": "推荐你使用这个小程序",
"url": "m.q.qq.com/a/s/aa3fbe89d8fa622322840bb53e7d9400",
"preview": "image/preview.png",
"appType": 0, // 0 小程序, 1 小游戏
"scene": 0,
"host": {
"uin": 0,
"nick": ""
},
"shareTemplateId": "",
"shareTemplateData": {
"bottomBtnTxt": "",
"bottomBtnShow": "off"
},
"showLittleTail": "1", // 新增 ---是否展示ark卡片小尾巴 0不展示 1展示
"gamePoints": "222", // 新增 ---积分
"gamePointsUrl": "https://q.qq.com", // 新增 ---跳转积分中心链接
};
this.iconUIObj = view.GetUIObject("icon");
this.titleUIObj = view.GetUIObject("title");
this.descUIObj = view.GetUIObject("desc");
this.titleForFooterUIObj = view.GetUIObject("titleForFooter");
this.footIconUIObj = view.GetUIObject("footIcon");
this.previewUIObj = view.GetUIObject("preview");
this.buttonWrapUIObj = view.GetUIObject("buttonWrap");
this.buttonTextUIObj = view.GetUIObject("buttonText");
this.originWrapUIObj = view.GetUIObject("originWrap");
this.originTexture = this.originWrapUIObj.GetTexture("originTexture");
this.titleViewUIObj = view.GetUIObject("titleView");
this.titleTexture = this.titleViewUIObj.GetTexture("titleTexture");
this.previewViewUIObj = view.GetUIObject("previewView");
this.previewTexture = this.previewViewUIObj.GetTexture("previewTexture");
this.buttonTexture = this.buttonWrapUIObj.GetTexture("buttonTexture");
this.littleTail = view.GetUIObject("littleTail");
this.gamePointsText = view.GetUIObject("gamePointsText");
this.miniappIconUIObj = view.GetUIObject("miniappIcon");
this.wxMiniappIconUIObj = view.GetUIObject("wxMiniappIcon");
this.footerTitleUIObj = view.GetUIObject("footerTitle");
this.previewPicUIObj = view.GetUIObject("previewPic");
this.blueBar = view.GetUIObject("blueBar");
this.blueBarTexture = this.blueBar.GetTexture("blueBarTexture");
var viewSize = this.view.GetSize();
this.OnResize(viewSize.width, viewSize.height);
this.Update();
// 绑定点击事件
var self = this;
this.titleViewUIObj.AttachEvent("OnClick", function() {
self.jumpMiniApp();
});
this.previewViewUIObj.AttachEvent("OnClick", function() {
self.jumpMiniApp();
});
this.originWrapUIObj.AttachEvent("OnClick", function() {
self.clickOriginWrapUI();
});
},
Deinitialize: function() {
ArkWindow.console.log("Deinitialize " + appView);
},
OnConfigChange(config) {
// 夜间模式适配
var isDarkMode = ArkWindow.theme.isDarkMode();
if (isDarkMode) {
this.darkModeAdapt(this.metaData);
} else {
this.lightModeAdapt(this.metaData);
}
},
OnResize: function() {
ArkWindow.console.log("OnResize " + appView);
this.Update();
},
OnSetValue: function(sender, value) {
ArkWindow.console.log("share game OnSetValue:", value);
this.metaData = value;
// 判断是否是频道
var info = ArkWindow.util.getContainerInfo(this.view);
var chatType = info.chatType;
var type = parseInt(chatType, 10);
// var type = 7; // 频道测试代码
// 7表示频道
if (type === 7) {
this.isGuild = true;
} else {
this.isGuild = false;
this.footerTitleUIObj.SetStyle("display:flex;flex:1;paddingLeft:5;paddingTop:3;");
this.blueBar.SetVisible(false);
}
// 如果是频道,则进行样式适配
if (this.isGuild) {
this.guildStyleAdapt();
}
// if (util.isiOS()) {
this.previewPicUIObj.SetStyle("display:block;width:100%;height:195;");
// }
// 夜间模式适配
this.darkModeAdapt(value);
// 简洁模式适配
this.conciseModeAdapt();
// if (app.config && app.config.theme) {
// var theme = app.config.theme;
// if (theme && theme.mode === "concise") {
// // 极简白
// if (theme.themeId === '2971') {
// this.originTexture.SetValue(0xFFEBEDF5);
// this.titleTexture.SetValue(0xFFF5F6FA);
// this.previewTexture.SetValue(0xFFF5F6FA);
// this.buttonTexture.SetValue(0xFFF5F6FA);
// } else if (theme.themeId === '2921' || theme.themeId === '1015712') {
// // 素雅灰
// // 1015715 代表TIM
// this.originTexture.SetValue(0xFFEBEDF5);
// }
// }
// }
var self = this;
this.metaData = value.detail_1 || this.metaData;
ArkWindow.console.log("share game metaData:");
ArkWindow.console.log(this.metaData);
this.Update();
// 曝光上报
var compassData = {
uin: this.metaData.host && this.metaData.host.uin || "",
appid: this.metaData.appid,
refer: this.metaData.scene,
actiontype: "ark",
sub_actiontype: "ark_share",
reserves_action: "expo",
reserves2: "com.tencent.miniapp_01",
reserves3: appView,
reserves4: this.metaData.type == 1 ? "friendPay" : "",
reserves5: ArkWindow.util.getContainerInfo(self.view).group ? "group" : "c2c"
};
ArkWindow.report.compass(compassData, "dc04239");
// 更新 desc 后,需要修复 desc 的高度,最多两行,超出截断
var descHeight = this.descUIObj.GetSize().height;
ArkWindow.console.log("descHeight:", descHeight);
if (ArkWindow.util.isiOS()) {
ArkWindow.console.log("isiOS");
if (descHeight > 24) {
this.descUIObj.SetStyle("display:block;height:52;margin:2 10 0 4;");
} else {
this.descUIObj.SetStyle("display:block;height:26;margin:2 10 0 4;");
}
} else if (ArkWindow.util.isAndroid()) {
ArkWindow.console.log("isAndroid");
if (descHeight > 23.3) {
this.descUIObj.SetStyle("display:block;height:50;margin:5 10 0 4;");
} else {
this.descUIObj.SetStyle("display:block;height:25;margin:5 10 0 4;");
}
} else {
// pc
ArkWindow.console.log("isiOS");
if (descHeight > 24) {
this.descUIObj.SetStyle("display:block;height:52;margin:2 10 0 4;");
} else {
this.descUIObj.SetStyle("display:block;height:22;margin:4 10 0 4;");
}
}
},
Update: function() {
ArkWindow.console.log("Update", this.metaData.icon);
if (this.metaData.icon) {
ArkWindow.util.setImage(this.metaData.icon, this.iconUIObj, function(err) {
if (err) {
ArkWindow.console.error("set Image error", err);
}
});
}
// 开发者配置展示按钮和按钮文案
if (this.metaData.shareTemplateId && this.metaData.shareTemplateData && this.metaData.shareTemplateData.bottomBtnShow && this.metaData.shareTemplateData.bottomBtnShow == "on") {
ArkWindow.console.log("bottomBtn txt: ", this.metaData.shareTemplateData.bottomBtnTxt);
this.buttonTextUIObj.SetValue(this.metaData.shareTemplateData.bottomBtnTxt || "");
this.buttonWrapUIObj.SetStyle("display:flex;flexDirection:row;alignItems:center;justifyContent:center;");
ArkWindow.console.log("display bottom btn");
} else {
ArkWindow.console.log("hide bottom btn");
this.buttonWrapUIObj.SetStyle("display:none;");
}
this.titleUIObj.SetValue(this.metaData.title);
this.descUIObj.SetValue(this.metaData.desc);
this.titleForFooterUIObj.SetValue(ArkWindow.util.getFootTitleByAppType(this.metaData.appType));
this.footIconUIObj.SetValue(ArkWindow.util.getFootIconByAppType(this.metaData.appType));
// 微信小程序的特殊处理
this.wxAppHandle();
ArkWindow.console.log("Update", this.metaData.preview);
if (this.metaData.preview) {
ArkWindow.util.setImage(this.metaData.preview, this.previewUIObj, function(err) {
if (err) {
ArkWindow.console.error("set Image error", err);
}
});
}
// ark小尾巴
var self = this;
if (!parseInt(this.metaData.showLittleTail, 10)) {
this.littleTail.SetVisible(false);
} else {
this.littleTail.SetVisible(true);
// 积分
var gamePoints = parseInt(this.metaData.gamePoints, 10) || 0;
// 积分跳转链接
var gamePointsUrl = this.metaData.gamePointsUrl || "";
if (gamePoints) {
this.gamePointsText.SetValue("你有一个" + gamePoints + "积分礼包待领取");
} else {
this.gamePointsText.SetValue("惊喜积分好礼等你来领");
}
this.littleTail.AttachEvent("OnClick", function() {
gamePointsUrl = ArkWindow.util.fixurl(gamePointsUrl);
ArkWindow.console.log("gamePointsUrl:", gamePointsUrl);
arkWeb.QQ.OpenUrl(gamePointsUrl, self.view.GetRoot());
});
}
},
jumpMiniApp: function() {
var self = this;
ArkWindow.console.log(appView + ' OnClick');
//上报到ark表
ArkWindow.util.Report(this.view.GetRoot().GetID(), 3, "Button.OnClick");
// 微信小程序低版本兼容
var businessType = this.metaData && this.metaData.businessType || 0;
var upgradeUrl = 'https://im.qq.com/mobileqq';
var isWxApp = parseInt(businessType, 10) == 2;
// 如果是微信小程并且版本低于8.8.80
if (isWxApp && ArkWindow.util.isCurrentQQVersionBelowTargetVersion("8.8.80", "8.8.80")) {
arkWeb.QQ.OpenUrl(upgradeUrl, this.view.GetRoot());
return;
}
var url = this.metaData["url"];
url = ArkWindow.util.fixurl(url);
url = ArkWindow.util.getMiniAppUrl(url, self.metaData["scene"], self.view);
ArkWindow.console.log("OpenUrl url:", url);
ArkWindow.console.log("befor OpenUrl");
arkWeb.QQ.OpenUrl(url, self.view.GetRoot());
ArkWindow.console.log("after OpenUrl");
// 点击上报
var containerInfo = ArkWindow.util.getContainerInfo(this.view);
var compassData = {
uin: this.metaData.host && this.metaData.host.uin || "",
appid: this.metaData.appid,
refer: this.metaData.scene,
actiontype: "ark",
sub_actiontype: "ark_share",
reserves_action: "click",
reserves2: "com.tencent.miniapp_01",
reserves3: appView,
reserves4: this.metaData.type == 1 ? "friendPay" : "",
reserves5: ArkWindow.util.getChatTypeName(containerInfo.chatType),
app_type: this.metaData.appType || 0,
};
ArkWindow.report.compass(compassData, "dc04239");
},
clickOriginWrapUI: function() {
ArkWindow.console.log("clickOriginWrapUI");
ArkWindow.console.log(this.metaData.appType);
if (Number(this.metaData.appType) !== 1 || !this.metaData.appType) {
// 非小游戏走原有的跳转逻辑
this.jumpMiniApp();
return;
}
var url = "mqqapi://hippy/open?bundleName=miniGameCenter";
arkWeb.QQ.OpenUrl(url, this.view.GetRoot());
// 点击上报
var containerInfo = ArkWindow.util.getContainerInfo(this.view);
var compassData = {
uin: this.metaData.host && this.metaData.host.uin || "",
appid: this.metaData.appid,
refer: this.metaData.scene,
actiontype: "ark",
sub_actiontype: "ark_share",
reserves_action: "click_minigamestore",
reserves2: "com.tencent.miniapp_01",
reserves3: appView,
reserves5: ArkWindow.util.getChatTypeName(containerInfo.chatType),
touin: containerInfo.chatUIN,
app_type: this.metaData.appType || 0,
};
ArkWindow.report.compass(compassData, "dc04239");
},
// 修改背景颜色
setBackgroundColor: function(color) {
this.originTexture.SetValue(color);
this.titleTexture.SetValue(color);
this.previewTexture.SetValue(color);
this.buttonTexture.SetValue(color);
},
// 频道ark样式适配
guildStyleAdapt: function() {
ArkWindow.console.log('guildStyleAdapt');
// 1. 修改背景颜色
this.setBackgroundColor(0xFFEEEEF2);
// 2. 加蓝条
this.blueBarTexture.SetValue(0xFF0099FF);
// 3. 隐藏icon图标
this.miniappIconUIObj.SetVisible(false);
this.previewViewUIObj.SetStyle("display:block;width:auto;padding:0 10 0 10;");
if (ArkWindow.util.isAndroid()) {
this.previewPicUIObj.SetStyle("display:block;width:100%;height:205;");
}
},
// 夜间模式适配
darkModeAdapt: function(value) {
var isDarkMode = ArkWindow.theme.isDarkMode() || false;
ArkWindow.console.log('darkModeAdapt', isDarkMode);
ArkWindow.console.log('current mode is dark?:', isDarkMode);
if (isDarkMode && !this.isGuild) {
this.setBackgroundColor(0xFF262626);
this.titleUIObj.SetTextColor(0xFF666666);
this.descUIObj.SetTextColor(0xFFFFFFFF);
this.titleForFooterUIObj.SetTextColor(0xFF666666);
this.originTexture.SetValue(0xFF262626);
}
},
// 白天模式适配
lightModeAdapt: function(value) {
var isDarkMode = ArkWindow.theme.isDarkMode();
ArkWindow.console.log('lightModeAdapt', isDarkMode);
ArkWindow.console.log('current mode is dark?:', isDarkMode);
if (!isDarkMode && !this.isGuild) {
this.setBackgroundColor(0xFFFFFFFF);
this.titleUIObj.SetTextColor(0xffB2B2B2);
this.descUIObj.SetTextColor(0xFF222222);
this.titleForFooterUIObj.SetTextColor(0xFFB2B2B2);
this.originTexture.SetValue(0xFFFFFFFF);
}
},
// 简洁模式适配
conciseModeAdapt: function() {
var isConciseMode = ArkWindow.theme.isConciseMode() || false;
var isDarkMode = ArkWindow.theme.isDarkMode() || false;
ArkWindow.console.log('current mode is concise?:', isConciseMode);
if (isConciseMode && !this.isGuild && !isDarkMode) {
this.setBackgroundColor(0xFFFFFFFF);
this.originTexture.SetValue(0xFFFFFFFF);
// 隐藏icon图标
this.miniappIconUIObj.SetVisible(false);
this.footerTitleUIObj.SetStyle("display:flex;flex:1;paddingLeft:12;paddingTop:1;");
}
},
// 微信小程序的一些特殊处理
wxAppHandle: function() {
// 0小程序 1小游戏 2微信小程序
var businessType = this.metaData && this.metaData.businessType || 0;
var appType = this.metaData && this.metaData.appType || 0;
var isWxApp = parseInt(businessType, 10) == 2;
var isMiniGame = parseInt(businessType, 10) == 1 || appType == 1;
if (isWxApp) {
this.wxMiniappIconUIObj.SetVisible(true);
this.miniappIconUIObj.SetVisible(false);
this.titleForFooterUIObj.SetValue('微信小程序');
} else if (isMiniGame) {
// QQ小游戏
this.wxMiniappIconUIObj.SetVisible(false);
this.miniappIconUIObj.SetVisible(true);
this.titleForFooterUIObj.SetValue('进入小游戏中心>');
} else {
this.wxMiniappIconUIObj.SetVisible(false);
this.miniappIconUIObj.SetVisible(true);
this.titleForFooterUIObj.SetValue('QQ小程序');
}
}
}
};
})();
var global$3 = ArkWindow;
(function() {
// 搞成闭包,避免污染全局变量
var appView = "view_95A06A1683C80BECC99BE5CC7B6D706B";
global$3[appView] = {
appView: appView,
ViewModel: {
New: function(view) {
var model = Object.create(this);
model.Initialize(view);
return model;
},
Initialize: function(view) {
ArkWindow.console.log("initialize " + appView);
this.view = view;
this.setvalue = false;
// demo数据
this.metaData = {
"appid": "1109595906", //小游戏appid
"icon": "https://miniapp.gtimg.cn/public/appicon/c755fac4b7473c4bb58726e30da3b60a_200.jpg", //小游戏的icon
"name": "垃圾分类管家", //小游戏名称
"title": "妈妈再也不用担心我倒错垃圾了~!", //小游戏转发标题
"imageUrl": "https://sola.gtimg.cn/aoi/sola/20200611201432_TVQLFtRsTk.png", //背景图片url
"path": "https://m.q.qq.com/a/s/a5a2744860397489cfcabe29667d9c9e",
"appType": 0, // 0 小程序, 1 小游戏 //转发路径
"scene": 1036, //场景值,用于上报
"host": {
"uin": 0, //模版发送人的uin,用于上报
"nick": ""
},
"shareTemplateId": "xxxxxxxxxxxxxx", //模版id
"shareTemplateData": { //模版id对应的内容
"bottomBtnTxt": "打开" // 底部按钮文案
}
};
this.iconUIObj = view.GetUIObject("icon");
this.nameUIObj = view.GetUIObject("name");
this.titleUIObj = view.GetUIObject("title");
this.imageUrlUIObj = view.GetUIObject("imageUrl");
this.bottomBtnTxtUIObj = view.GetUIObject("bottomBtnTxt");
this.buttonWrapUIObj = view.GetUIObject("buttonWrap");
this.titleWrapUIObj = view.GetUIObject("titleWrap");
this.titleWrapTexture = this.titleWrapUIObj.GetTexture("titleWrapTexture");
this.previewWrapUIObj = view.GetUIObject("previewWrap");
this.previewWrapTexture = this.previewWrapUIObj.GetTexture("previewWrapTexture");
this.buttonContainUIObj = view.GetUIObject("buttonContain");
this.buttonContainTexture = this.buttonContainUIObj.GetTexture("buttonContainTexture");
this.footerUIObj = view.GetUIObject("footer");
this.footerTexture = this.footerUIObj.GetTexture("footerTexture");
this.footerTitleUIObj = view.GetUIObject("footerTitle");
this.footIconUIObj = view.GetUIObject("footIcon");
var viewSize = this.view.GetSize();
this.OnResize(viewSize.width, viewSize.height);
this.Update();
// 绑定点击事件
var self = this;
this.titleWrapUIObj.AttachEvent("OnClick", function() {
self.OnClick();
});
this.previewWrapUIObj.AttachEvent("OnClick", function() {
self.OnClick();
});
this.buttonContainUIObj.AttachEvent("OnClick", function() {
self.OnClick();
});
this.footerUIObj.AttachEvent("OnClick", function() {
self.clickOriginWrapUI();
});
},
Deinitialize: function() {
ArkWindow.console.log("Deinitialize " + appView);
},
OnResize: function() {
ArkWindow.console.log("OnResize " + appView);
this.Update();
},
OnSetValue: function(sender, value) {
if (this.setvalue) {
return;
}
this.setvalue = true;
ArkWindow.console.log("OnSetValue", value, ArkWindow.app.config);
var self = this;
this.metaData = value.invitation_1 || this.metaData;
this.Update();
// 更新 title 后,需要修复 title 的高度,最多两行,超出截断
var titleHeight = this.titleUIObj.GetSize().height;
ArkWindow.console.log("titleHeight:", titleHeight);
if (ArkWindow.util.isiOS()) {
ArkWindow.console.log("isiOS");
if (titleHeight > 24) {
this.titleUIObj.SetStyle("display:block;height:15vw;margin:5 10 0 10;");
} else {
this.titleUIObj.SetStyle("display:block;height:7.5vw;margin:5 10 2 10;");
}
} else if (ArkWindow.util.isAndroid()) {
ArkWindow.console.log("isAndroid");
if (titleHeight > 23.3) {
this.titleUIObj.SetStyle("display:block;height:12.8vw;margin:5 10 2 10;");
} else {
this.titleUIObj.SetStyle("display:block;height:6.4vw;margin:5 10 4 10;");
}
}
// 夜间模式适配
this.darkModeAdapt();
// 曝光上报
var compassData = {
uin: this.metaData.host && this.metaData.host.uin || "",
appid: this.metaData.appid,
refer: this.metaData.scene,
actiontype: "ark",
sub_actiontype: "ark_share",
reserves_action: "expo",
reserves2: "com.tencent.miniapp_01",
reserves3: appView,
reserves4: "",
reserves5: ArkWindow.util.getContainerInfo(self.view).group ? "group" : "c2c"
};
ArkWindow.report.compass(compassData, "dc04239");
},
Update: function() {
ArkWindow.console.log("Update img", this.metaData.icon);
if (this.metaData.icon) {
ArkWindow.util.setImage(this.metaData.icon, this.iconUIObj, function(err) {
if (err) {
ArkWindow.console.error("set Image error", err);
}
});
}
//按钮文案
if (this.metaData.shareTemplateId && this.metaData.shareTemplateData && this.metaData.shareTemplateData.bottomBtnTxt) {
ArkWindow.console.log("bottomBtn txt: ", this.metaData.shareTemplateData.bottomBtnTxt);
this.bottomBtnTxtUIObj.SetValue(this.metaData.shareTemplateData.bottomBtnTxt || "");
ArkWindow.console.log("display bottom btn");
} else {
this.bottomBtnTxtUIObj.SetValue("");
this.buttonWrapUIObj.SetStyle("flex:1;display:flex;flexDirection:row;alignItems:center;justifyContent:center;paddingTop:10");
ArkWindow.console.log("hide bottom btn");
}
this.nameUIObj.SetValue(this.metaData.name);
this.titleUIObj.SetValue(this.metaData.title);
this.footerTitleUIObj.SetValue(ArkWindow.util.getFootTitleByAppType(this.metaData.appType));
this.footIconUIObj.SetValue(ArkWindow.util.getFootIconByAppType(this.metaData.appType));
ArkWindow.console.log("Update img", this.metaData.imageUrl);
if (this.metaData.imageUrl) {
ArkWindow.util.setImage(this.metaData.imageUrl, this.imageUrlUIObj, function(err) {
if (err) {
ArkWindow.console.error("set Image error", err);
}
});
}
},
OnClick: function(sender, x, y, button, keyState) {
var self = this;
ArkWindow.console.log(appView + ' OnClick');
//上报到ark表
ArkWindow.util.Report(this.view.GetRoot().GetID(), 3, "Button.OnClick");
var url = this.metaData["path"];
url = ArkWindow.util.fixurl(url);
url = ArkWindow.util.getMiniAppUrl(url, self.metaData["scene"], self.view);
ArkWindow.console.log("OpenUrl url:", url);
ArkWindow.console.log("befor OpenUrl");
arkWeb.QQ.OpenUrl(url, self.view.GetRoot());
ArkWindow.console.log("after OpenUrl");
// 点击上报
var containerInfo = ArkWindow.util.getContainerInfo(this.view);
var compassData = {
uin: this.metaData.host && this.metaData.host.uin || "",
appid: this.metaData.appid,
refer: this.metaData.scene,
actiontype: "ark",
sub_actiontype: "ark_share",
reserves_action: "click",
reserves2: "com.tencent.miniapp_01",
reserves3: appView,
reserves4: "",
reserves5: ArkWindow.util.getChatTypeName(containerInfo.chatType),
app_type: this.metaData.appType || 0,
};
ArkWindow.report.compass(compassData, "dc04239");
},
clickOriginWrapUI: function() {
ArkWindow.console.log("clickOriginWrapUI");
ArkWindow.console.log(this.metaData.appType);
if (Number(this.metaData.appType) === 0 || !this.metaData.appType) {
this.OnClick();
return;
}
var url = "mqqapi://hippy/open?bundleName=miniGameCenter";
arkWeb.QQ.OpenUrl(url, this.view.GetRoot());
// 点击上报
var containerInfo = ArkWindow.util.getContainerInfo(this.view);
var compassData = {
uin: this.metaData.host && this.metaData.host.uin || "",
appid: this.metaData.appid,
refer: this.metaData.scene,
actiontype: "ark",
sub_actiontype: "ark_share",
reserves_action: "click_minigamestore",
reserves2: "com.tencent.miniapp_01",
reserves3: appView,
reserves5: ArkWindow.util.getChatTypeName(containerInfo.chatType),
touin: containerInfo.chatUIN,
app_type: this.metaData.appType || 0,
};
ArkWindow.report.compass(compassData, "dc04239");
},
// 修改背景颜色
setBackgroundColor: function(color) {
this.originTexture.SetValue(color);
this.titleTexture.SetValue(color);
this.previewTexture.SetValue(color);
this.buttonTexture.SetValue(color);
},
darkModeAdapt: function() {
var isDarkMode = ArkWindow.theme.isDarkMode() || false;
ArkWindow.console.log('current mode is dark?:', isDarkMode);
if (isDarkMode) {
// 修改背景颜色
this.titleWrapTexture.SetValue(0xFF262626);
this.previewWrapTexture.SetValue(0xFF262626);
this.buttonContainTexture.SetValue(0xFF262626);
this.footerTexture.SetValue(0xFF2E2E2E);
// 修改字体颜色
this.nameUIObj.SetTextColor(0xFF666666);
this.titleUIObj.SetTextColor(0xFF999999);
this.bottomBtnTxtUIObj.SetTextColor(0xFF0066CC);
this.footerTitleUIObj.SetTextColor(0xFF666666);
}
}
}
};
})();
var global$2 = ArkWindow;
(function() {
// 搞成闭包,避免污染全局变量
var appView = "view_4473A8CC09D60E4199A9EF0437B14D50";
global$2[appView] = {
appView: appView,
ViewModel: {
New: function(view) {
var model = Object.create(this);
model.Initialize(view);
return model;
},
Initialize: function(view) {
ArkWindow.console.log("initialize " + appView);
this.view = view;
this.setvalue = false;
// demo数据
this.metaData = {
"appid": "1109595906", //小游戏appid
"icon": "https://miniapp.gtimg.cn/public/appicon/c755fac4b7473c4bb58726e30da3b60a_200.jpg", //小游戏的icon
"name": "垃圾分类管家", //小游戏名称
"title": "妈妈再也不用担心我倒错垃圾了", //小游戏转发标题
"imageUrl": "https://sola.gtimg.cn/aoi/sola/20200611201432_TVQLFtRsTk.png", //背景图片url
"path": "https://m.q.qq.com/a/s/a5a2744860397489cfcabe29667d9c9e", //转发路径
"scene": 1036, //场景值,用于上报
"host": {
"uin": 0, //模版发送人的uin,用于上报
"nick": ""
},
"shareTemplateId": "xxxxxxxxxxxxxx", //模版id
"shareTemplateData": { //模版id对应的内容
"bottomBtnTxt": "打开", // 底部按钮文案
"achievementGrade": 1, //过了多少关
"achievementUnit": "关" //单位
}
};
this.iconUIObj = view.GetUIObject("icon");
this.nameUIObj = view.GetUIObject("name");
this.titleUIObj = view.GetUIObject("title");
this.imageUrlUIObj = view.GetUIObject("imageUrl");
this.bottomBtnTxtUIObj = view.GetUIObject("bottomBtnTxt");
this.buttonWrapUIObj = view.GetUIObject("buttonWrap");
this.maskUIObj = view.GetUIObject("mask");
this.achieveUIObj = view.GetUIObject("achieve");
this.achieveTextUIObj = view.GetUIObject("achieveText");
this.achieveUnitUIObj = view.GetUIObject("achieveUnit");
this.titleWrapUIObj = view.GetUIObject("titleWrap");
this.titleWrapTexture = this.titleWrapUIObj.GetTexture("titleWrapTexture");
this.previewWrapUIObj = view.GetUIObject("previewWrap");
this.previewWrapTexture = this.previewWrapUIObj.GetTexture("previewWrapTexture");
this.buttonContainUIObj = view.GetUIObject("buttonContain");
this.buttonContainTexture = this.buttonContainUIObj.GetTexture("buttonContainTexture");
this.footerUIObj = view.GetUIObject("footer");
this.footerTexture = this.footerUIObj.GetTexture("footerTexture");
this.footerTitleUIObj = view.GetUIObject("footerTitle");
this.footIconUIObj = view.GetUIObject("footIcon");
var viewSize = this.view.GetSize();
this.OnResize(viewSize.width, viewSize.height);
this.Update();
// 绑定点击事件
var self = this;
this.titleWrapUIObj.AttachEvent("OnClick", function() {
self.OnClick();
});
this.previewWrapUIObj.AttachEvent("OnClick", function() {
self.OnClick();
});
this.buttonContainUIObj.AttachEvent("OnClick", function() {
self.OnClick();
});
this.footerUIObj.AttachEvent("OnClick", function() {
self.clickOriginWrapUI();
});
},
Deinitialize: function() {
ArkWindow.console.log("Deinitialize " + appView);
},
OnResize: function() {
ArkWindow.console.log("OnResize " + appView);
this.Update();
},
OnSetValue: function(sender, value) {
if (this.setvalue) {
return;
}
this.setvalue = true;
ArkWindow.console.log("OnSetValue", value, ArkWindow.app.config);
var self = this;
this.metaData = value.invitation_2 || this.metaData;
this.Update();
// 更新 title 后,需要修复 title 的高度,最多两行,超出截断
var titleHeight = this.titleUIObj.GetSize().height;
ArkWindow.console.log("titleHeight:", titleHeight);
if (ArkWindow.util.isiOS()) {
ArkWindow.console.log("isiOS");
if (titleHeight > 24) {
this.titleUIObj.SetStyle("display:block;height:15vw;margin:5 10 0 10;");
} else {
this.titleUIObj.SetStyle("display:block;height:7.5vw;margin:5 10 2 10;");
}
} else if (ArkWindow.util.isAndroid()) {
ArkWindow.console.log("isAndroid");
if (titleHeight > 23.3) {
this.titleUIObj.SetStyle("display:block;height:12.8vw;margin:5 10 2 10;");
} else {
this.titleUIObj.SetStyle("display:block;height:6.4vw;margin:5 10 4 10;");
}
}
// 夜间模式适配
this.darkModeAdapt();
// 曝光上报
var compassData = {
uin: this.metaData.host && this.metaData.host.uin || "",
appid: this.metaData.appid,
refer: this.metaData.scene,
actiontype: "ark",
sub_actiontype: "ark_share",
reserves_action: "expo",
reserves2: "com.tencent.miniapp_01",
reserves3: appView,
reserves4: "",
reserves5: ArkWindow.util.getContainerInfo(self.view).group ? "group" : "c2c"
};
ArkWindow.report.compass(compassData, "dc04239");
},
Update: function() {
ArkWindow.console.log("Update img", this.metaData.icon);
if (this.metaData.icon) {
ArkWindow.util.setImage(this.metaData.icon, this.iconUIObj, function(err) {
if (err) {
ArkWindow.console.error("set Image error", err);
}
});
}
// 按钮文案
if (this.metaData.shareTemplateId && this.metaData.shareTemplateData && this.metaData.shareTemplateData.bottomBtnTxt) {
ArkWindow.console.log("bottomBtn txt: ", this.metaData.shareTemplateData.bottomBtnTxt);
this.bottomBtnTxtUIObj.SetValue(this.metaData.shareTemplateData.bottomBtnTxt || "");
ArkWindow.console.log("display bottom btn");
} else {
this.bottomBtnTxtUIObj.SetValue("");
this.buttonWrapUIObj.SetStyle("flex:1;display:flex;flexDirection:row;alignItems:center;justifyContent:center;paddingTop:10");
ArkWindow.console.log("hide bottom btn");
}
//成就相关
if (this.metaData.shareTemplateId && this.metaData.shareTemplateData && this.metaData.shareTemplateData.achievementGrade) {
ArkWindow.console.log("achievementGrade txt: ", this.metaData.shareTemplateData.achievementGrade);
ArkWindow.console.log("achieveUnit txt: ", this.metaData.shareTemplateData.achievementGrade);
this.achieveTextUIObj.SetValue(this.metaData.shareTemplateData.achievementGrade || "");
this.achieveUnitUIObj.SetValue(this.metaData.shareTemplateData.achievementUnit || "");
ArkWindow.console.log("display achievementGrade txt");
} else {
this.achieveTextUIObj.SetValue("");
this.achieveUnitUIObj.SetValue("");
this.maskUIObj.SetStyle("display:none;");
this.achieveUIObj.SetStyle("display:none;");
ArkWindow.console.log("hide achievementGrade bg");
}
this.nameUIObj.SetValue(this.metaData.name);
this.titleUIObj.SetValue(this.metaData.title);
this.footerTitleUIObj.SetValue(ArkWindow.util.getFootTitleByAppType(this.metaData.appType));
this.footIconUIObj.SetValue(ArkWindow.util.getFootIconByAppType(this.metaData.appType));
ArkWindow.console.log("Update img", this.metaData.imageUrl);
if (this.metaData.imageUrl) {
ArkWindow.util.setImage(this.metaData.imageUrl, this.imageUrlUIObj, function(err) {
if (err) {
ArkWindow.console.error("set Image error", err);
}
});
}
},
OnClick: function(sender, x, y, button, keyState) {
var self = this;
ArkWindow.console.log(appView + ' OnClick');
//上报到ark表
ArkWindow.util.Report(this.view.GetRoot().GetID(), 3, "Button.OnClick");
var url = this.metaData["path"];
url = ArkWindow.util.fixurl(url);
url = ArkWindow.util.getMiniAppUrl(url, self.metaData["scene"], self.view);
ArkWindow.console.log("OpenUrl url:", url);
ArkWindow.console.log("befor OpenUrl");
arkWeb.QQ.OpenUrl(url, self.view.GetRoot());
ArkWindow.console.log("after OpenUrl");
// 点击上报
var containerInfo = ArkWindow.util.getContainerInfo(this.view);
var compassData = {
uin: this.metaData.host && this.metaData.host.uin || "",
appid: this.metaData.appid,
refer: this.metaData.scene,
actiontype: "ark",
sub_actiontype: "ark_share",
reserves_action: "click",
reserves2: "com.tencent.miniapp_01",
reserves3: appView,
reserves4: "",
reserves5: ArkWindow.util.getChatTypeName(containerInfo.chatType),
app_type: this.metaData.appType || 0,
};
ArkWindow.report.compass(compassData, "dc04239");
},
clickOriginWrapUI: function() {
ArkWindow.console.log("clickOriginWrapUI");
ArkWindow.console.log(this.metaData.appType);
if (Number(this.metaData.appType) === 0 || !this.metaData.appType) {
this.OnClick();
return;
}
var url = "mqqapi://hippy/open?bundleName=miniGameCenter";
arkWeb.QQ.OpenUrl(url, this.view.GetRoot());
// 点击上报
var containerInfo = ArkWindow.util.getContainerInfo(this.view);
var compassData = {
uin: this.metaData.host && this.metaData.host.uin || "",
appid: this.metaData.appid,
refer: this.metaData.scene,
actiontype: "ark",
sub_actiontype: "ark_share",
reserves_action: "click_minigamestore",
reserves2: "com.tencent.miniapp_01",
reserves3: appView,
reserves5: ArkWindow.util.getChatTypeName(containerInfo.chatType),
touin: containerInfo.chatUIN,
app_type: this.metaData.appType || 0,
};
ArkWindow.report.compass(compassData, "dc04239");
},
darkModeAdapt: function() {
var isDarkMode = ArkWindow.theme.isDarkMode() || false;
ArkWindow.console.log('current mode is dark?:', isDarkMode);
if (isDarkMode) {
// 修改背景颜色
this.titleWrapTexture.SetValue(0xFF262626);
this.previewWrapTexture.SetValue(0xFF262626);
this.buttonContainTexture.SetValue(0xFF262626);
this.footerTexture.SetValue(0xFF2E2E2E);
// 修改字体颜色
this.nameUIObj.SetTextColor(0xFF666666);
this.titleUIObj.SetTextColor(0xFF999999);
this.bottomBtnTxtUIObj.SetTextColor(0xFF0066CC);
this.footerTitleUIObj.SetTextColor(0xFF666666);
}
}
}
};
})();
var global$1 = ArkWindow;
(function() {
// 搞成闭包,避免污染全局变量
var appView = "view_472ADE9D43609B0F5AB20E86B765EEA3";
global$1[appView] = {
appView: appView,
ViewModel: {
New: function(view) {
var model = Object.create(this);
model.Initialize(view);
return model;
},
Initialize: function(view) {
ArkWindow.console.log("initialize " + appView);
this.view = view;
this.setvalue = false;
// demo数据
this.metaData = {
"appid": "1109595906", //小游戏appid
"icon": "https://miniapp.gtimg.cn/public/appicon/c755fac4b7473c4bb58726e30da3b60a_200.jpg", //小游戏的icon
"name": "垃圾分类管家", //小游戏名称
"title": "妈妈再也不用担心我", //小游戏转发标题
"imageUrl": "https://sola.gtimg.cn/aoi/sola/20200611201432_TVQLFtRsTk.png", //背景图片url
"path": "https://m.q.qq.com/a/s/a5a2744860397489cfcabe29667d9c9e",
"appType": 0, // 0 小程序, 1 小游戏 //转发路径
"scene": 1036, //场景值,用于上报
"host": {
"uin": 0, //模版发送人的uin,用于上报
"nick": ""
},
"shareTemplateId": "xxxxxxxxxxxxxx", //模版id
"shareTemplateData": { //模版id对应的内容
"bottomBtnTxt": "打开", // 底部按钮文案
"giftList": [ //礼包列表
{
"giftName": "露娜",
"giftImg": "https://sola.gtimg.cn/aoi/sola/20200612152246_qBuoWIP9OK.png"
},
{
"giftName": "露娜",
"giftImg": "https://sola.gtimg.cn/aoi/sola/20200612152246_qBuoWIP9OK.png"
},
{
"giftName": "露娜",
"giftImg": "https://sola.gtimg.cn/aoi/sola/20200612152246_qBuoWIP9OK.png"
}
]
}
};
this.iconUIObj = view.GetUIObject("icon");
this.nameUIObj = view.GetUIObject("name");
this.titleUIObj = view.GetUIObject("title");
this.imageUrlUIObj = view.GetUIObject("imageUrl");
this.bottomBtnTxtUIObj = view.GetUIObject("bottomBtnTxt");
this.buttonWrapUIObj = view.GetUIObject("buttonWrap");
this.maskUIObj = view.GetUIObject("mask");
this.gift1UIObj = view.GetUIObject("gift1");
this.gift2UIObj = view.GetUIObject("gift2");
this.gift3UIObj = view.GetUIObject("gift3");
this.gift1ImgUIObj = view.GetUIObject("gift1Img");
this.gift1TextUIObj = view.GetUIObject("gift1Text");
this.gift2ImgUIObj = view.GetUIObject("gift2Img");
this.gift2TextUIObj = view.GetUIObject("gift2Text");
this.gift3ImgUIObj = view.GetUIObject("gift3Img");
this.gift3TextUIObj = view.GetUIObject("gift3Text");
this.titleWrapUIObj = view.GetUIObject("titleWrap");
this.titleWrapTexture = this.titleWrapUIObj.GetTexture("titleWrapTexture");
this.previewWrapUIObj = view.GetUIObject("previewWrap");
this.previewWrapTexture = this.previewWrapUIObj.GetTexture("previewWrapTexture");
this.buttonContainUIObj = view.GetUIObject("buttonContain");
this.buttonContainTexture = this.buttonContainUIObj.GetTexture("buttonContainTexture");
this.footerUIObj = view.GetUIObject("footer");
this.footerTexture = this.footerUIObj.GetTexture("footerTexture");
this.footerTitleUIObj = view.GetUIObject("footerTitle");
this.footIconUIObj = view.GetUIObject("footIcon");
var viewSize = this.view.GetSize();
this.OnResize(viewSize.width, viewSize.height);
this.Update();
// 绑定点击事件
var self = this;
this.titleWrapUIObj.AttachEvent("OnClick", function() {
self.OnClick();
});
this.previewWrapUIObj.AttachEvent("OnClick", function() {
self.OnClick();
});
this.buttonContainUIObj.AttachEvent("OnClick", function() {
self.OnClick();
});
this.footerUIObj.AttachEvent("OnClick", function() {
self.clickOriginWrapUI();
});
},
Deinitialize: function() {
ArkWindow.console.log("Deinitialize " + appView);
},
OnResize: function() {
ArkWindow.console.log("OnResize " + appView);
this.Update();
},
OnSetValue: function(sender, value) {
if (this.setvalue) {
return;
}
this.setvalue = true;
ArkWindow.console.log("OnSetValue", value, ArkWindow.app.config);
var self = this;
this.metaData = value.invitation_3 || this.metaData;
this.Update();
// 更新 title 后,需要修复 title 的高度,最多两行,超出截断
var titleHeight = this.titleUIObj.GetSize().height;
ArkWindow.console.log("titleHeight:", titleHeight);
if (ArkWindow.util.isiOS()) {
ArkWindow.console.log("isiOS");
if (titleHeight > 24) {
this.titleUIObj.SetStyle("display:block;height:15vw;margin:5 10 0 10;");
} else {
this.titleUIObj.SetStyle("display:block;height:7.5vw;margin:5 10 2 10;");
}
} else if (ArkWindow.util.isAndroid()) {
ArkWindow.console.log("isAndroid");
if (titleHeight > 23.3) {
this.titleUIObj.SetStyle("display:block;height:12.8vw;margin:5 10 2 10;");
} else {
this.titleUIObj.SetStyle("display:block;height:6.4vw;margin:5 10 4 10;");
}
}
// 夜间模式适配
this.darkModeAdapt();
// 曝光上报
var compassData = {
uin: this.metaData.host && this.metaData.host.uin || "",
appid: this.metaData.appid,
refer: this.metaData.scene,
actiontype: "ark",
sub_actiontype: "ark_share",
reserves_action: "expo",
reserves2: "com.tencent.miniapp_01",
reserves3: appView,
reserves4: "",
reserves5: ArkWindow.util.getContainerInfo(self.view).group ? "group" : "c2c"
};
ArkWindow.report.compass(compassData, "dc04239");
},
Update: function() {
ArkWindow.console.log("Update img", this.metaData.icon);
if (this.metaData.icon) {
ArkWindow.util.setImage(this.metaData.icon, this.iconUIObj, function(err) {
if (err) {
ArkWindow.console.error("set Image error", err);
}
});
}
// 按钮文案
if (this.metaData.shareTemplateId && this.metaData.shareTemplateData && this.metaData.shareTemplateData.bottomBtnTxt) {
ArkWindow.console.log("bottomBtn txt: ", this.metaData.shareTemplateData.bottomBtnTxt);
this.bottomBtnTxtUIObj.SetValue(this.metaData.shareTemplateData.bottomBtnTxt || "");
ArkWindow.console.log("display bottom btn");
} else {
this.bottomBtnTxtUIObj.SetValue("");
this.buttonWrapUIObj.SetStyle("flex:1;display:flex;flexDirection:row;alignItems:center;justifyContent:center;paddingTop:10");
ArkWindow.console.log("hide bottom btn");
}
//奖品相关
if (this.metaData.shareTemplateId && this.metaData.shareTemplateData && this.metaData.shareTemplateData.giftList && this.metaData.shareTemplateData.giftList.length) {
ArkWindow.console.log("giftList:", this.metaData.shareTemplateData.giftList);
var giftList = this.metaData.shareTemplateData.giftList;
for (var i = 0; i < 3; i++) {
if (giftList[i] && giftList[i].giftImg) {
ArkWindow.console.log(this["gift" + (i + 1) + "UIObj"]);
this["gift" + (i + 1) + "UIObj"].SetStyle("display:flex;flexDirection:column;alignItems:center;");
this["gift" + (i + 1) + "TextUIObj"].SetValue(giftList[i].giftName || "");
ArkWindow.util.setImage(giftList[i].giftImg, this["gift" + (i + 1) + "ImgUIObj"], function(err) {
if (err) {
ArkWindow.console.error("set Image error", err);
}
});
} else {
this["gift" + (i + 1) + "UIObj"].SetStyle("display:none;");
}
}
ArkWindow.console.log("display giftList");
} else {
this.maskUIObj.SetStyle("display:none;");
this["gift1UIObj"].SetStyle("display:none;");
this["gift2UIObj"].SetStyle("display:none;");
this["gift3UIObj"].SetStyle("display:none;");
ArkWindow.console.log("hide giftList");
}
this.nameUIObj.SetValue(this.metaData.name);
this.titleUIObj.SetValue(this.metaData.title);
this.footerTitleUIObj.SetValue(ArkWindow.util.getFootTitleByAppType(this.metaData.appType));
this.footIconUIObj.SetValue(ArkWindow.util.getFootIconByAppType(this.metaData.appType));
ArkWindow.console.log("Update img", this.metaData.imageUrl);
if (this.metaData.imageUrl) {
ArkWindow.util.setImage(this.metaData.imageUrl, this.imageUrlUIObj, function(err) {
if (err) {
ArkWindow.console.error("set Image error", err);
}
});
}
},
OnClick: function(sender, x, y, button, keyState) {
var self = this;
ArkWindow.console.log(appView + ' OnClick');
//上报到ark表
ArkWindow.util.Report(this.view.GetRoot().GetID(), 3, "Button.OnClick");
var url = this.metaData["path"];
url = ArkWindow.util.fixurl(url);
url = ArkWindow.util.getMiniAppUrl(url, self.metaData["scene"], self.view);
ArkWindow.console.log("OpenUrl url:", url);
ArkWindow.console.log("befor OpenUrl");
arkWeb.QQ.OpenUrl(url, self.view.GetRoot());
ArkWindow.console.log("after OpenUrl");
// 点击上报
var containerInfo = ArkWindow.util.getContainerInfo(this.view);
var compassData = {
uin: this.metaData.host && this.metaData.host.uin || "",
appid: this.metaData.appid,
refer: this.metaData.scene,
actiontype: "ark",
sub_actiontype: "ark_share",
reserves_action: "click",
reserves2: "com.tencent.miniapp_01",
reserves3: appView,
reserves4: "",
reserves5: ArkWindow.util.getChatTypeName(containerInfo.chatType),
app_type: this.metaData.appType || 0,
};
ArkWindow.report.compass(compassData, "dc04239");
},
clickOriginWrapUI: function() {
ArkWindow.console.log("clickOriginWrapUI");
ArkWindow.console.log(this.metaData.appType);
if (Number(this.metaData.appType) === 0 || !this.metaData.appType) {
this.OnClick();
return;
}
var url = "mqqapi://hippy/open?bundleName=miniGameCenter";
arkWeb.QQ.OpenUrl(url, this.view.GetRoot());
// 点击上报
var containerInfo = ArkWindow.util.getContainerInfo(this.view);
var compassData = {
uin: this.metaData.host && this.metaData.host.uin || "",
appid: this.metaData.appid,
refer: this.metaData.scene,
actiontype: "ark",
sub_actiontype: "ark_share",
reserves_action: "click_minigamestore",
reserves2: "com.tencent.miniapp_01",
reserves3: appView,
reserves5: ArkWindow.util.getChatTypeName(containerInfo.chatType),
touin: containerInfo.chatUIN,
app_type: this.metaData.appType || 0,
};
ArkWindow.report.compass(compassData, "dc04239");
},
darkModeAdapt: function() {
var isDarkMode = ArkWindow.theme.isDarkMode() || false;
ArkWindow.console.log('current mode is dark?:', isDarkMode);
if (isDarkMode) {
// 修改背景颜色
this.titleWrapTexture.SetValue(0xFF262626);
this.previewWrapTexture.SetValue(0xFF262626);
this.buttonContainTexture.SetValue(0xFF262626);
this.footerTexture.SetValue(0xFF2E2E2E);
// 修改字体颜色
this.nameUIObj.SetTextColor(0xFF666666);
this.titleUIObj.SetTextColor(0xFF999999);
this.bottomBtnTxtUIObj.SetTextColor(0xFF0066CC);
this.footerTitleUIObj.SetTextColor(0xFF666666);
}
}
}
};
})();
var global = ArkWindow;
(function() {
// 搞成闭包,避免污染全局变量
var appView = 'view_A5D6E190E8364AB2AF4BF9F53A9BE1DC';
global[appView] = {
appView: appView,
ViewModel: {
New: function(view) {
var model = Object.create(this);
model.Initialize(view);
return model;
},
Initialize: function(view) {
ArkWindow.console.log('initialize ' + appView);
this.view = view;
this.setvalue = false;
// demo数据
this.metaData = {
appid: '1110285175', //小游戏appid
icon: 'https://miniapp.gtimg.cn/public/appicon/c755fac4b7473c4bb58726e30da3b60a_200.jpg', //小游戏的icon
name: '群橱窗', //小游戏名称
title: '妈妈再也不用担心我', //小游戏转发标题
imageUrl: 'https://sola.gtimg.cn/aoi/sola/20200611201432_TVQLFtRsTk.png', //背景图片url
path: 'https://m.q.qq.com/a/s/a5a2744860397489cfcabe29667d9c9e', //转发路径
scene: 1036, //场景值,用于上报
host: {
uin: 0, //模版发送人的uin,用于上报
nick: '',
},
shareTemplateId: 'xxxxxxxxxxxxxx', // 模版id
shareTemplateData: {
// 模版id对应的内容
bottomBtnTxt: '呵呵呵www', // 底部按钮文案
productList: [], // 商品列表 字段名直接用源数据
},
};
this.titleUIObj = view.GetUIObject('title');
this.imageUrlUIObj = view.GetUIObject('imageUrl');
this.bottomBtnTxtUIObj = view.GetUIObject('bottomBtnTxt');
this.buttonWrapUIObj = view.GetUIObject('buttonWrap');
this.item0UIObj = view.GetUIObject('item-0');
this.item1UIObj = view.GetUIObject('item-1');
this.item2UIObj = view.GetUIObject('item-2');
this.item0ImgUIObj = view.GetUIObject('item-0-image');
this.item0TextUIObj = view.GetUIObject('item-0-text');
this.item1ImgUIObj = view.GetUIObject('item-1-image');
this.item1TextUIObj = view.GetUIObject('item-1-text');
this.item2ImgUIObj = view.GetUIObject('item-2-image');
this.item2TextUIObj = view.GetUIObject('item-2-text');
var viewSize = this.view.GetSize();
this.OnResize(viewSize.width, viewSize.height);
this.Update();
},
Deinitialize: function() {
ArkWindow.console.log('Deinitialize ' + appView);
},
OnResize: function() {
ArkWindow.console.log('OnResize ' + appView);
this.Update();
},
OnSetValue: function(sender, value) {
if (this.setvalue) {
return;
}
this.setvalue = true;
ArkWindow.console.log('OnSetValue', value, ArkWindow.app.config);
var self = this;
this.metaData = value.invitation_gshop || this.metaData;
this.Update();
// 曝光上报
var compassData = {
uin: (this.metaData.host && this.metaData.host.uin) || '',
appid: this.metaData.appid,
refer: this.metaData.scene,
actiontype: 'ark',
sub_actiontype: 'ark_share',
reserves_action: 'expo',
reserves2: 'com.tencent.miniapp_01',
reserves3: appView,
reserves4: '',
reserves5: ArkWindow.util.getContainerInfo(self.view).group ? 'group' : 'c2c',
};
ArkWindow.report.compass(compassData, 'dc04239');
},
Update: function() {
// 按钮文案
if (
this.metaData.shareTemplateId &&
this.metaData.shareTemplateData &&
this.metaData.shareTemplateData.bottomBtnTxt
) {
ArkWindow.console.log(
'bottomBtn txt: ',
this.metaData.shareTemplateData.bottomBtnTxt
);
this.bottomBtnTxtUIObj.SetValue(
this.metaData.shareTemplateData.bottomBtnTxt || ''
);
ArkWindow.console.log('display bottom btn');
} else {
this.bottomBtnTxtUIObj.SetValue('');
this.buttonWrapUIObj.SetStyle(
'flex:1;display:flex;flexDirection:row;alignItems:center;justifyContent:center;paddingTop:10'
);
ArkWindow.console.log('hide bottom btn');
}
//奖品相关
if (
this.metaData.shareTemplateId &&
this.metaData.shareTemplateData &&
this.metaData.shareTemplateData.productList &&
this.metaData.shareTemplateData.productList.length
) {
ArkWindow.console.log(
'productList:',
this.metaData.shareTemplateData.productList
);
var productList = this.metaData.shareTemplateData.productList;
for (var i = 0; i < 3; i++) {
const itemUIObj = this['item' + i + 'UIObj'];
const itemTextObj = this['item' + i + 'TextUIObj'];
const priceTextObj = itemTextObj.GetChild('price');
if (productList[i] && productList[i].img) {
const {
title = '', sales = 0, price, ori_price = 0, url
} = productList[i];
itemUIObj.SetStyle(
'display:flex;flexDirection:row;alignItems:center;justifyContent:space-between;marginTop:10'
);
itemUIObj.AttachEvent('OnClick', function(view) {
ArkWindow.console.log(url + ' OnItemClick');
url && arkWeb.QQ.OpenUrl(ArkWindow.util.fixurl(url));
});
itemTextObj.SetValue({
['item-' + i + '-title']: title
});
if (sales > 0) { //销量大于 0 才展示
itemTextObj.SetValue({
['item-' + i + '-sales']: '销量' + sales + '件'
});
}
if (!price) {
priceTextObj.SetStyle('display:none;');
}
priceTextObj.SetValue({
['item-' + i + '-price']: '¥' + price,
['item-' + i + '-priceInt']: parseInt(price / 100, 10),
['item-' + i + '-priceFloat']: String(price).substr(-2)
});
if (ori_price != null && price != ori_price) { // 原价不等于现价才展示
priceTextObj.SetValue({
['item-' + i + '-oprice']: '原价: ¥' + ori_price
});
}
ArkWindow.util.setImage(
productList[i].img,
this['item' + i + 'ImgUIObj'],
function(err) {
if (err) {
ArkWindow.console.error('set Image error', err);
}
}
);
} else {
itemUIObj.SetStyle('display:none;');
}
}
ArkWindow.console.log('display productList');
} else {
this['item0UIObj'].SetStyle('display:none;');
this['item1UIObj'].SetStyle('display:none;');
this['item2UIObj'].SetStyle('display:none;');
ArkWindow.console.log('hide productList');
}
},
OnClick: function(sender, x, y, button, keyState) {
var self = this;
//上报到ark表
ArkWindow.util.Report(this.view.GetRoot().GetID(), 3, 'Button.OnClick');
var url = this.metaData['path'];
url = ArkWindow.util.fixurl(url);
url = ArkWindow.util.getMiniAppUrl(url, self.metaData['scene'], self.view);
ArkWindow.console.log('OpenUrl url:', url);
ArkWindow.console.log('befor OpenUrl');
arkWeb.QQ.OpenUrl(url, self.view.GetRoot());
ArkWindow.console.log('after OpenUrl');
// 点击上报
var compassData = {
uin: (this.metaData.host && this.metaData.host.uin) || '',
appid: this.metaData.appid,
refer: this.metaData.scene,
actiontype: 'ark',
sub_actiontype: 'ark_share',
reserves_action: 'click',
reserves2: 'com.tencent.miniapp_01',
reserves3: appView,
reserves4: '',
reserves5: ArkWindow.util.getContainerInfo(self.view).group ? 'group' : 'c2c',
};
ArkWindow.report.compass(compassData, 'dc04239');
},
},
};
})();
ArkGlobalContext._setViewTemplate('invitation.xml', `
`);
const uniqueApplicationId = (function() {
function S4() {
return (((1+Math.random())*0x10000)|0).toString(16).substring(1);
}
return (S4()+S4()+"-"+S4()+"-"+S4()+"-"+S4()+"-"+S4()+S4()+S4());
})();
/**
* 有很多地方会用到这里数据.所以这里最好还是挂载到app上.
* @returns
* @update 2022-07-30 22:47:10
* @author alawnxu
* @description 这里之前挂载app上.不过后面发现不可行.因为在Ark视图里面有注册了很多事件.这些事件的会直接调用里面声明的全局方法.这个时候就有可能不是在某一个对象上了.
*/
ArkWindow.getExtendObject = function () {
var appKey = '4ff195c8c387ba6859d8ce9595420d92';
return {
appid: 'com.tencent.miniapp_01',
appKey,
images: [{"name":"image/icon-minigame@2x.png","url":""},{"name":"image/icon-miniprogram@2x.png","url":""},{"name":"image/icon.png","url":"https://ark-release-1251316161.file.myqcloud.com/com.tencent.miniapp_01/image/icon.png"},{"name":"image/integral_icon.png","url":""},{"name":"image/invitationAchieveBg.png","url":"https://ark-release-1251316161.file.myqcloud.com/com.tencent.miniapp_01/image/invitationAchieveBg.png"},{"name":"image/invitationBgMask.png","url":""},{"name":"image/invitationGiftFrame.png","url":"https://ark-release-1251316161.file.myqcloud.com/com.tencent.miniapp_01/image/invitationGiftFrame.png"},{"name":"image/lineBg.png","url":""},{"name":"image/link.png","url":""},{"name":"image/more.png","url":""},{"name":"image/next.png","url":""},{"name":"image/notificationIcon.png","url":""},{"name":"image/notificationRighDis.png","url":""},{"name":"image/preview.png","url":"https://ark-release-1251316161.file.myqcloud.com/com.tencent.miniapp_01/image/preview.png"},{"name":"image/wxMiniappIcon.png","url":""}],
fonts: {"size.12":{"fontFamily":" PingFangSC-Regular,Helvetica,sans-serif,Microsoft YaHei","size":12,"bold":false},"bold.12":{"fontFamily":" PingFangSC-Regular,Helvetica,sans-serif,Microsoft YaHei","size":12,"bold":true},"size.14":{"fontFamily":"PingFangSC-Regular,Helvetica,sans-serif,Microsoft YaHei","size":14,"bold":false},"size.17":{"fontFamily":" PingFangSC-Semibold,Helvetica,sans-serif,Microsoft YaHei","size":17,"bold":false},"app.default":{"fontFamily":"Helvetica,sans-serif,Microsoft YaHei","size":12,"bold":false},"app.bold":{"fontFamily":"Helvetica,sans-serif,Microsoft YaHei","size":12,"bold":true},"bold.14":{"fontFamily":"Helvetica,sans-serif,Microsoft YaHei","size":14,"bold":true},"bold.17":{"fontFamily":"Helvetica,sans-serif,Microsoft YaHei","size":17,"bold":true},"size.20":{"fontFamily":"Helvetica,sans-serif,Microsoft YaHei","size":20,"bold":false},"size.25":{"fontFamily":"Helvetica,sans-serif,Microsoft YaHei","size":25,"bold":false},"size.30":{"fontFamily":"Helvetica,sans-serif,Microsoft YaHei","size":30,"bold":false},"size.40":{"fontFamily":"Helvetica,sans-serif,Microsoft YaHei","size":40,"bold":false},"size.50":{"fontFamily":"Helvetica,sans-serif,Microsoft YaHei","size":50,"bold":false},"bold.60":{"fontFamily":"Helvetica,sans-serif,Microsoft YaHei","size":60,"bold":true}},
appVersion: "1.0.1.41",
buildVersion: "20230223224235",
styles: {"origin-wrap":{"display":"flex","flexDirection":"row","alignItems":"center","height":"34pt"},"origin-wrap__hd":{"display":"block","width":"15pt","height":"15pt","marginLeft":"15pt"},"origin-wrap__icon":{"display":"block","width":"100%","height":"100%"},"origin-wrap__bd":{"display":"block","flex":1,"marginLeft":"0.666vw"}},
applicationEvents: [{"eventName":"OnCreateView","callback":"app.OnCreateView"},{"eventName":"OnDestroyView","callback":"app.OnDestroyView"},{"eventName":"OnStartup","callback":"app.OnStartup"},{"eventName":"OnConfigChange","callback":"app.OnConfigChange"}],
applicationId: appKey + '_' + uniqueApplicationId,
urlWhiteList: []
};
};
/**
* 释放资源
* @description 使用_命名,防止被重写
*/
ArkWindow._destroyResource_ = function () {
ArkGlobalContext.clearTemplates();
};
function createApp(options) {
const templates = ArkGlobalContext.getViewTemplates();
return new arkWeb.WebARKView({
/**
* 这里之前是导出的唯一的对象.不过后面发现不可行.因为在Ark视图里面有注册了很多事件.这些事件的会直接调用里面声明的全局方法.这个时候就有可能不是在某一个对象上了.
* @author alawnxu
* @date 2022-07-30 22:41:12
* @see
* com.tencent.qq_vip_collect_card_template
*
*
*
*
* 而游戏中心的大部分都是:
* com.tencent.gamecenter.gshare
*
*
*
*
* 还有多个的:
* com.tencent.mobileqq.reading
*
*
*
* 而根据不同的模板调用不同的初始化方法在正常不过.所以这里统一导出ArkWindow
*/
app: ArkWindow,
templates,
...(options || {}),
});
}
return createApp;
}));